Funktionen zum Übergeben von Meldungen
Die Asynchronous Agents Library stellt mehrere Funktionen bereit, mit denen Sie Meldungen zwischen Komponenten übergeben können.
Diese Meldungsübergabefunktionen werden mit den verschiedenen Meldungsblocktypen verwendet.Weitere Informationen zu den Meldungsblocktypen, die von der Concurrency Runtime definiert werden, finden Sie unter Asynchrone Nachrichtenblöcke.
Abschnitte
In diesem Thema werden die folgenden Meldungsübergabefunktionen beschrieben:
send und asend
receive und try_receive
Beispiele
send und asend
Die concurrency::send Funktion synchron sendet eine Nachricht an das angegebene Ziel und die concurrency::asend Funktion asynchron sendet eine Nachricht an das angegebene Ziel.Die Funktionen asend und die Funktion send warten, bis das Ziel angibt, dass es eine schließlich Meldung akzeptiert oder ablehnt wird.
Die send-Funktion wartet, bis das Ziel die Meldung akzeptiert oder ablehnt, bevor eine Rückgabe erfolgt.Die send-Funktion gibt true zurück, wenn die Meldung zugestellt wurde, andernfalls gibt sie false zurück.Da die send-Funktion synchron funktioniert, wartet die send-Funktion, bis das Ziel die Meldung empfängt, bevor eine Rückgabe erfolgt.
Die asend-Funktion wartet hingegen nicht, bis das Ziel die Meldung akzeptiert oder abgelehnt hat, bevor eine Rückgabe erfolgt.Die asend-Funktion gibt stattdessen true zurück, wenn das Ziel die Meldung schließlich akzeptiert.Andernfalls gibt asendfalse zurück, um anzugeben, dass das Ziel die Meldung entweder abgelehnt hat oder die Entscheidung, ob die Meldung angenommen wird, aufgeschoben hat.
Top
receive und try_receive
Die concurrency::receive und concurrency::try_receive Funktionen Lesen von Daten aus einer angegebenen Quelle.Die receive-Funktion wartet, bis die Daten verfügbar sind, wohingegen die try_receive-Funktion sofort eine Rückgabe liefert.
Verwenden Sie die receive-Funktion, wenn Sie die Daten benötigen, um fortfahren zu können.Verwenden Sie die try_receive-Funktion, wenn Sie den aktuellen Kontext nicht blockieren dürfen oder die Daten nicht benötigen, um fortfahren zu können.
Top
Beispiele
Beispiele für die Verwendung der Funktionen send, asend und receive finden Sie in den folgenden Themen:
Gewusst wie: Implementieren verschiedener Producer-Consumer-Muster
Gewusst wie: Bereitstellen von Arbeitsfunktionen für die call- und transformer-Klassen
Gewusst wie: Verwenden von transformer in einer Datenpipeline
Gewusst wie: Senden einer Nachricht in regelmäßigen Intervallen
Top