(PECL pthreads >= 2.0.0)
Pool::submitTo — Envía una tarea a un worker específico para su ejecución
Envía la tarea al worker especificado en el Pool. Los workers están indexados a partir de 0, y solo existirán si el pool necesita crearlos (ya que los threads se generan de forma perezosa).
worker
El worker donde apilar la tarea, indexado a partir de 0
.
size
La tarea, para su ejecución
El identificador del Worker que ha aceptado la tarea.
Ejemplo #1 Envío de una tarea a un worker específico
<?php
class Task extends Threaded {
public function run() {
var_dump(Thread::getCurrentThreadID());
}
}
$pool = new Pool(2);
$pool->submit(new Task());
for ($i = 0; $i < 5; ++$i) {
$pool->submitTo(0, new Task()); // apilar todas las tareas en el primer worker
}
$pool->submitTo(1, new Task()); // No es posible apilar la tarea en el segundo worker ya que aún no existe
$pool->shutdown();
?>
El resultado del ejemplo sería:
int(4475011072) int(4475011072) int(4475011072) int(4475011072) int(4475011072) int(4475011072) Fatal error: Uncaught Exception: The selected worker (1) does not exist in %s:%d