バッファリングされた送信チャネルとバッファリングされていない受信チャネルの同時選択
Go では、チャネルはゴルーチン間の同時通信のためのメカニズムを提供します。この質問では、バッファリングされた送信チャネルとバッファリングされていない受信チャネルを同時に選択し、チャネルの可用性に基づいてゴルーチンがデータを送信または受信できるようにする方法について説明します。
バッファリングされた送信チャネルでの選択
]データを受信前にキューに入れることができる s などのバッファリングされた送信チャネルを選択するには、次のコマンドを使用できます。構文:
case s <- v: // Send value `v` to channel `s`
ただし、バッファリングされたチャネルでは、送信する値を事前に評価する必要があるため、競合状態により古いデータが送信される可能性があります。
バッファなし受信チャネルでの選択
データが送信されない、r などのバッファなし受信チャネルでの選択キューに入れられているため、簡単です:
case r := <-r: // Receive value `r` from channel `r`
デフォルトでは、受信チャネルでの選択は、データが利用可能になるまでブロックされます。
同時選択
バッファリングされた送信チャネル s とバッファリングされていない受信チャネル r の両方を同時に選択するには、次の select ステートメントを使用できます:
select { case s <- v: fmt.Println("Sent value:", v) case vr := <-r: fmt.Println("Received:", vr) default: // No channels are ready, do something else, e.g. sleep }
古いデータの処理
select ステートメントの外で v := valueToSend() を使用して送信する値を評価するとき、チャネル s がいっぱいになるかチャネル r になる可能性があります。値が送信される前にデータを受信します。データが古くならないようにするために、デフォルトのケースを select ステートメントに追加できます。このデフォルトのケースは、どちらのチャネルも準備完了でない場合に実行され、短いスリープを実行するために使用でき、チャネルが準備完了状態に達するまでの時間を与えられます。
直接チャネル長チェックの回避
チャネルの長さや容量を確認して送信または受信することは信頼できないことに注意することが重要です。チャネルの状態は、チェック時と送受信時の間に変化し、予期しないブロック動作を引き起こす可能性があります。
結論
デフォルトのケースで select ステートメントを使用すると、ゴルーチンバッファリングされた送信チャネルとバッファリングされていない受信チャネルを同時に選択できるため、チャネルの使用量とリソース効率が最適化されます。ただし、信頼性の高い通信を確保するには、古いデータの可能性を考慮し、チャネル長の直接チェックを避けることが重要です。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3