parallel/examples/parcel-process.php
Aaron Piotrowski 79a4f979f4
Update examples
2018-10-21 10:34:08 -05:00

36 lines
1.0 KiB
PHP

<?php
// The function returned by this script is run by shared-memory-process.php in a separate process.
// $argc and $argv are available in this process as any other cli PHP script.
use Amp\Delayed;
use Amp\Parallel\Sync\Channel;
use Amp\Parallel\Sync\SharedMemoryParcel;
return function (Channel $channel) use ($argv): \Generator {
if (!isset($argv[1])) {
throw new \Error("No parcel ID provided");
}
$id = $argv[1];
\printf("Child process using parcel ID %s\n", $id);
$parcel = SharedMemoryParcel::use($id);
$value = yield $parcel->synchronized(function (int $value) {
return $value + 1;
});
\printf("Value after modifying in child thread: %s\n", $value);
yield new Delayed(500); // Parent process should access parcel during this time.
// Unwrapping the parcel now should give value from parent process.
\printf("Value in child thread after being modified in main thread: %s\n", yield $parcel->unwrap());
yield $parcel->synchronized(function (int $value) {
return $value + 1;
});
};