Две корутины эффективно делят процессорное время

Корутина 1 — Обработка пользователей Итерация: 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);
}
});
Корутина 2 — Логирование + уведомления Итерация: 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
}
});
Timeline выполнения 0 ms
Корутина 1 готова
Корутина 2 готова
0255075100ms
CPU:
Ожидание
CPU работает
Ожидание БД
Ожидание сети
0 ms
Общее время
0 ms
Ожидание БД
0 ms
Ожидание сети
0 ms
Сэкономлено

Нажмите "Запустить" для начала

Визуализация показывает, как две корутины эффективно делят процессор. Пока одна ждёт ответа от базы данных или сети, другая выполняет полезную работу. Это кооперативная многозадачность.