Dos corrutinas comparten eficientemente el tiempo de CPU

Corrutina 1 — Procesamiento de usuarios Iteración: 0/3
$coro1 = spawn(function() {
$pdo = new PDO($dsn);
foreach ([1,2,3] as $id) {
$stmt = $pdo->prepare("SELECT * FROM users WHERE id=?");
$stmt->execute([$id]); // ⏳ 15ms
$user = $stmt->fetch();
processUser($user);
}
});
Corrutina 2 — Registro + Notificaciones Iteración: 0/3
$coro2 = spawn(function() {
$pdo = new PDO($dsn);
$socket = fsockopen($host, 9000);
foreach (['login','click','logout'] as $e) {
$stmt = $pdo->prepare("INSERT INTO logs VALUES(?)");
$stmt->execute([$e]); // ⏳ 12ms
fwrite($socket, $e); // ⏳ 20ms
}
});
Línea de tiempo de ejecución 0 ms
Corrutina 1 lista
Corrutina 2 lista
0255075100ms
CPU:
En espera
CPU trabajando
Esperando BD
Esperando red
0 ms
Tiempo total
0 ms
Espera BD
0 ms
Espera red
0 ms
Tiempo ahorrado

Haz clic en "Reproducir" para comenzar

Esta visualización muestra cómo dos corrutinas comparten eficientemente la CPU. Mientras una espera una respuesta de la base de datos o la red, la otra realiza trabajo útil. Esto es multitarea cooperativa.