Channel::close

(PHP 8.6+, True Async 1.0)

public Channel::close(): void

Schließt den Channel. Nach dem Schließen:

Ein erneuter Aufruf von close() auf einem bereits geschlossenen Channel verursacht keine Fehler.

Beispiele

Beispiel #1 Einen Channel nach dem Senden von Daten schließen

<?php

use Async\Channel;

$channel = new Channel(10);

spawn(function() use ($channel) {
    for ($i = 0; $i < 5; $i++) {
        $channel->send($i);
    }
    $channel->close(); // Signal an den Empfänger, dass keine weiteren Daten kommen
});

spawn(function() use ($channel) {
    foreach ($channel as $value) {
        echo "Empfangen: $value\n";
    }
    // foreach endet nach dem Schließen und Leeren des Puffers
    echo "Channel erschöpft\n";
});

Beispiel #2 Behandlung des Schließens durch wartende Coroutinen

<?php

use Async\Channel;

$channel = new Channel();

spawn(function() use ($channel) {
    try {
        $channel->send('data'); // Wartet auf einen Empfänger
    } catch (\Async\ChannelException $e) {
        echo "Channel geschlossen: {$e->getMessage()}\n";
    }
});

spawn(function() use ($channel) {
    delay(100); // Kurze Verzögerung
    $channel->close(); // Entsperrt den Sender mit einer Ausnahme
});

Siehe auch