I took the most basic demo of the pthreads PHP extension that uses the class Pool(this demo is https://github.com/krakjoe/pthreads#polyfill ) and expanded it a little, so I can get the results from the stream (or at least I I think I can):
$pool = new Pool(4);
foreach (range(1, 8) as $i) {
$pool->submit(new class($i) extends Threaded
{
public $i;
private $garbage = false;
public function __construct($i)
{
$this->i = $i;
}
public function run()
{
echo "Hello World\n";
$this->result = $this->i * 2;
$this->garbage = true;
}
public function isGarbage() : bool
{
return $this->garbage;
}
});
}
while ($pool->collect(function(Collectable $task) {
if ($task->isGarbage()) {
echo $task->i . ' ' . $task->result . "\n";
}
return $task->isGarbage();
})) continue;
$pool->shutdown();
What scares me is that it sometimes does not get results for all tasks:
Hello World
Hello World
Hello World
Hello World
Hello World
1 2
2 4
Hello World
Hello World
3 6
Hello World
7 14
4 8
8 16
Now two lines with 5 10and are 6 12missing, but I do not understand why. This happens only occasionally (maybe 1/10 works).
It seems that the original demo is for the older version pthreads, because there is an Collectableinterface that now automatically implements Threaded, if I'm not mistaken.
readme :
Pool:: collect .
, , - .
: Pool:: collect? pthreads PHP7 . , .
$pool = new Pool(4);
while (@$i++<10) {
$pool->submit(new class($i) extends Thread implements Collectable {
public $id;
private $garbage;
public function __construct($id) {
$this->id = $id;
}
public function run() {
sleep(1);
printf(
"Hello World from %d\n", $this->id);
$this->setGarbage();
}
public function setGarbage() {
$this->garbage = true;
}
public function isGarbage(): bool {
return $this->garbage;
}
});
}
while ($pool->collect(function(Collectable $work){
printf(
"Collecting %d\n", $work->id);
return $work->isGarbage();
})) continue;
$pool->shutdown();
, :
Hello World from 1
Collecting 1
Hello World from 2
Collecting 2
Hello World from 3
Collecting 3
Hello World from 4
Collecting 4
Hello World from 5
Collecting 5
Hello World from 6
Hello World from 7
Collecting 6
Collecting 7
Hello World from 8
Hello World from 9
Hello World from 10