1
0
mirror of https://github.com/danog/parallel.git synced 2024-12-02 17:52:14 +01:00
parallel/examples/thread.php

43 lines
1.2 KiB
PHP
Raw Normal View History

2015-08-07 01:59:25 +02:00
#!/usr/bin/env php
2015-07-14 00:30:59 +02:00
<?php
require dirname(__DIR__).'/vendor/autoload.php';
2015-07-14 00:30:59 +02:00
use Icicle\Concurrent\Threading\Thread;
use Icicle\Coroutine;
2015-07-14 00:30:59 +02:00
use Icicle\Loop;
2015-08-07 01:59:25 +02:00
$timer = Loop\periodic(1, function () {
static $i;
$i = $i ? ++$i : 1;
print "Demonstrating how alive the parent is for the {$i}th time.\n";
2015-08-07 01:59:25 +02:00
});
Coroutine\create(function () {
// Create a new child thread that does some blocking stuff.
2015-08-24 20:46:17 +02:00
$context = Thread::spawn(function () {
2015-08-18 17:12:06 +02:00
printf("\$this: %s\n", get_class($this));
2016-01-23 07:00:56 +01:00
printf("Received the following from parent: %s\n", yield from $this->receive());
2015-08-18 17:12:06 +02:00
2015-09-03 00:23:22 +02:00
print "Sleeping for 3 seconds...\n";
sleep(3); // Blocking call in thread.
2015-08-18 17:12:06 +02:00
2016-01-23 07:00:56 +01:00
yield from $this->send('Data sent from child.');
2015-09-03 00:23:22 +02:00
print "Sleeping for 2 seconds...\n";
sleep(2); // Blocking call in thread.
2016-01-23 07:00:56 +01:00
return 42;
});
2015-07-27 00:53:00 +02:00
2015-09-03 00:23:22 +02:00
print "Waiting 2 seconds to send start data...\n";
yield Coroutine\sleep(2);
2015-08-18 17:12:06 +02:00
2016-01-23 07:00:56 +01:00
yield from $context->send('Start data');
2015-08-18 17:12:06 +02:00
2016-01-23 07:00:56 +01:00
printf("Received the following from child: %s\n", yield from $context->receive());
printf("Thread ended with value %d!\n", yield from $context->join());
2015-08-18 17:12:06 +02:00
})->cleanup([$timer, 'stop'])->done();
2015-07-14 00:30:59 +02:00
Loop\run();