Coroutine::getId
(PHP 8.6+, True Async 1.0)
public Coroutine::getId(): int
Returns the unique integer identifier of the coroutine. The identifier is unique within the current PHP process.
Return Value
int – unique coroutine identifier.
Examples
Example #1 Basic usage
<?php
use function Async\spawn;
$coroutine1 = spawn(function() {
return "task 1";
});
$coroutine2 = spawn(function() {
return "task 2";
});
$id1 = $coroutine1->getId();
$id2 = $coroutine2->getId();
var_dump(is_int($id1)); // bool(true)
var_dump($id1 !== $id2); // bool(true)
Example #2 Logging with identifier
<?php
use function Async\spawn;
function loggedTask(string $name): \Async\Coroutine {
return spawn(function() use ($name) {
$id = \Async\current_coroutine()->getId();
echo "[coro:$id] Task '$name' started\n";
\Async\delay(1000);
echo "[coro:$id] Task '$name' completed\n";
});
}
See Also
- Coroutine::getSpawnLocation – Coroutine creation location
- current_coroutine() – Get the current coroutine