Lors de l'utilisation d'un seul canal avec plusieurs goroutines de récepteurs, il devient crucial de comprendre comment se produit la distribution des données. Alors que le canal lui-même est bloqué jusqu'à ce que les données soient disponibles, le comportement devient plus complexe une fois les données envoyées.
Contrairement aux attentes, tous les récepteurs ne reçoivent pas les données simultanément. Au lieu de cela, un seul récepteur est choisi au hasard pour recevoir les données, et le comportement de blocage cesse pour ce récepteur uniquement. Cela implique que les autres récepteurs resteront bloqués jusqu'à ce que davantage de données soient envoyées sur le canal.
Ce comportement inattendu vient du fait que Go utilise une approche pseudo-aléatoire pour sélectionner quel récepteur recevra les données. La spécification du langage souligne que, parmi les opérations de communication possibles, une seule au hasard est choisie si elles peuvent toutes se dérouler. Ce caractère pseudo-aléatoire garantit l'équité entre les destinataires mais rend le processus de sélection non déterministe.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!