1
0
mirror of https://github.com/danog/parallel.git synced 2025-01-22 22:11:11 +01:00
parallel/examples/thread.php

45 lines
1.2 KiB
PHP
Raw Normal View History

2015-08-06 18:59:25 -05:00
#!/usr/bin/env php
2015-07-13 17:30:59 -05:00
<?php
require dirname(__DIR__).'/vendor/autoload.php';
2015-07-13 17:30:59 -05:00
2017-06-17 18:31:35 +02:00
use Amp\Delayed;
2017-05-18 09:51:31 +02:00
use Amp\Loop;
2016-08-23 16:47:40 -05:00
use Amp\Parallel\Threading\Thread;
2016-08-18 11:04:48 -05:00
Loop::run(function () {
$timer = Loop::repeat(1000, function () {
2016-08-18 11:04:48 -05:00
static $i;
$i = $i ? ++$i : 1;
print "Demonstrating how alive the parent is for the {$i}th time.\n";
});
2017-05-18 09:51:31 +02:00
2016-08-18 11:04:48 -05:00
try {
// Create a new child thread that does some blocking stuff.
$context = Thread::spawn(function () {
printf("\$this: %s\n", get_class($this));
2017-05-18 09:51:31 +02:00
2016-08-18 11:04:48 -05:00
printf("Received the following from parent: %s\n", yield $this->receive());
2017-05-18 09:51:31 +02:00
2016-08-18 11:04:48 -05:00
print "Sleeping for 3 seconds...\n";
sleep(3); // Blocking call in thread.
2017-05-18 09:51:31 +02:00
2016-08-18 11:04:48 -05:00
yield $this->send("Data sent from child.");
2017-05-18 09:51:31 +02:00
2016-08-18 11:04:48 -05:00
print "Sleeping for 2 seconds...\n";
sleep(2); // Blocking call in thread.
2017-05-18 09:51:31 +02:00
2016-08-18 11:04:48 -05:00
return 42;
});
2017-05-18 09:51:31 +02:00
2016-08-18 11:04:48 -05:00
print "Waiting 2 seconds to send start data...\n";
2017-05-26 11:55:08 +02:00
yield new Delayed(2000);
2017-05-18 09:51:31 +02:00
2016-08-18 11:04:48 -05:00
yield $context->send("Start data");
2017-05-18 09:51:31 +02:00
2016-08-18 11:04:48 -05:00
printf("Received the following from child: %s\n", yield $context->receive());
printf("Thread ended with value %d!\n", yield $context->join());
} finally {
Loop::cancel($timer);
2016-08-18 11:04:48 -05:00
}
});