Channel Canale delle Coroutine
Il Channel è un meccanismo di comunicazione tra coroutine. Una coroutine può inviare dati nel canale, mentre un'altra coroutine può estrarre dati da esso, realizzando così sincronizzazione e condivisione dei dati tra le coroutine.
Suggerimento
Questa funzionalità richiede workerman>=5.1.0
Attenzione
- Supporto automatico del livello sottostante per Swoole/Swow/Fiber/Select/Event
- Quando si utilizza il driver Select/Event, i parametri di timeout per pop/push non sono supportati
<?php
use Workerman\Connection\TcpConnection;
use Workerman\Coroutine\Channel;
use Workerman\Coroutine;
use Workerman\Events\Swoole;
use Workerman\Protocols\Http\Request;
use Workerman\Worker;
require_once __DIR__ . '/vendor/autoload.php';
// Http Server
$worker = new Worker('http://0.0.0.0:8001');
$worker->eventLoop = Swoole::class; // Oppure Swow::class o Fiber::class
$worker->onMessage = function (TcpConnection $connection, Request $request) {
$channel = new Channel(2);
Coroutine::create(function () use ($channel) {
$channel->push('Task 1 Done');
});
Coroutine::create(function () use ($channel) {
$channel->push('Task 2 Done');
});
$result = [];
for ($i = 0; $i < 2; $i++) {
$result[] = $channel->pop();
}
$connection->send(json_encode($result)); // Risposta: ["Task 1 Done","Task 2 Done"]
};
Worker::runAll();
Descrizione dell'Interfaccia
interface ChannelInterface
{
/**
* Inviare dati al canale, supporta il timeout (unità in secondi), restituisce false in caso di timeout
*/
public function push(mixed $data, float $timeout = -1): bool;
/**
* Estrae dati dal canale, supporta il timeout (unità di timeout in secondi), restituisce false in caso di timeout
*/
public function pop(float $timeout = -1): mixed;
/**
* Ottiene la lunghezza dei dati nel canale
*/
public function length(): int;
/**
* Ottiene la capacità del canale
*/
public function getCapacity(): int;
/**
* Verifica se ci sono consumatori, ovvero se ci sono coroutine in attesa di estrarre dati
*/
public function hasConsumers(): bool;
/**
* Verifica se ci sono produttori, ovvero se ci sono coroutine in attesa di inviare dati nel canale
*/
public function hasProducers(): bool;
/**
* Chiude il canale
*/
public function close(): void;
}