International PHP Conference Berlin 2025

Pool::submit

(PECL pthreads >= 2.0.0)

Pool::submitSubmits an object for execution

Description

public Pool::submit(Threaded $task): int

Submit the task to the next Worker in the Pool

Parameters

task

The task for execution

Return Values

the identifier of the Worker executing the object

Examples

Example #1 Submitting Tasks

<?php
class MyWork extends Threaded {

public function
run() {
/* ... */
}
}

class
MyWorker extends Worker {

public function
__construct(Something $something) {
$this->something = $something;
}

public function
run() {
/** ... **/
}
}

$pool = new Pool(8, \MyWorker::class, [new Something()]);
$pool->submit(new MyWork());
var_dump($pool);
?>

The above example will output:

object(Pool)#1 (6) {
  ["size":protected]=>
  int(8)
  ["class":protected]=>
  string(8) "MyWorker"
  ["workers":protected]=>
  array(1) {
    [0]=>
    object(MyWorker)#4 (1) {
      ["something"]=>
      object(Something)#5 (0) {
      }
    }
  }
  ["work":protected]=>
  array(1) {
    [0]=>
    object(MyWork)#3 (1) {
      ["worker"]=>
      object(MyWorker)#5 (1) {
        ["something"]=>
        object(Something)#6 (0) {
        }
      }
    }
  }
  ["ctor":protected]=>
  array(1) {
    [0]=>
    object(Something)#2 (0) {
    }
  }
  ["last":protected]=>
  int(1)
}

add a note

User Contributed Notes

There are no user contributed notes for this page.
To Top