Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Perlu penjelasan lanjut tentang perbezaan antara saluran tidak buffer (iaitu kapasiti 0) dan saluran buffer kapasiti 1 di Golang

Perlu penjelasan lanjut tentang perbezaan antara saluran tidak buffer (iaitu kapasiti 0) dan saluran buffer kapasiti 1 di Golang

PHPz
PHPzke hadapan
2024-02-14 10:15:09546semak imbas

需要进一步澄清 Golang 中无缓冲通道(即容量 0)与容量 1 的缓冲通道之间的差异

editor php Banana perlu menjelaskan lagi perbezaan antara saluran tidak buffer (kapasiti 0) dan saluran buffer dengan kapasiti 1 di Golang. Di Golang, saluran ialah satu mekanisme penting untuk komunikasi antara coroutine, dan saluran tidak buffer dan saluran buffer ialah dua jenis saluran. Saluran tidak buffer memerlukan penghantar dan penerima bersedia pada masa yang sama untuk mencapai komunikasi segerak, manakala saluran buffer membenarkan penghantar menghantar data ke dalam saluran walaupun penerima tidak bersedia untuk menerimanya. Pemahaman lanjut tentang perbezaan antara kedua-dua jenis saluran ini akan membantu untuk lebih memahami dan menggunakan mekanisme saluran di Golang.

Kandungan soalan

Dalam pautan di bawah, salah satu jawapan yang diberikan berkenaan perbezaan antara saluran tidak buffer 1 kapasiti dan saluran penimbal ialah hanya jika saluran " tidak dibuffer (kapasiti sifar) Komunikasi hanya akan berjaya apabila penghantar dan penerima kedua-duanya bersedia”.

Apabila penulis mengatakan kedua-dua pengirim dan penerima sudah bersedia, apakah sebenarnya maksudnya? Secara kronologi, betulkah saya mengatakan bahawa seseorang mesti mendahului yang lain? Jika ya, betulkah saya mengatakan bahawa penerima mesti bersedia sebelum pengirim?

Perbezaan antara kapasiti penampan saluran 0 dan 1 dalam golang

Saya telah cuba mencari penjelasan di saluran rasmi dan tidak rasmi. Namun, saya masih belum menemui jawapan yang memuaskan. Yang paling dekat saya datang ialah penjelasan di bawah.

Adakah ini bermakna sebarang kod yang ditulis di bawah ch <- "C" (jika kapasiti = 3) masih akan dijalankan? Berbalik kepada soalan asal saya tentang perbezaan antara kapasiti 0 dan 1, adakah ini bermakna mana-mana kod di bawah pengirim tidak akan dijalankan (untuk kapasiti = 0)? Sebaliknya, jika kapasiti = 1, walaupun kapasiti penuh ialah 1, kod di bawah di sebelah penghantar masih akan berjalan begitu lama?

https://www.golinuxcloud.com/golang-buffered-channel/

Terima kasih!

Penyelesaian

Apabila penulis mengatakan bahawa kedua-dua pengirim dan penerima sudah bersedia, apakah maksudnya sebenarnya?

Ini bermakna satu goroutine sedang melaksanakan terima dan satu lagi goroutine sedang melaksanakan hantar. Tidak kira goroutine mana yang mula beroperasi dahulu.

Dalam erti kata lain, goroutine menghantar menghalang sehingga goroutine lain menerima data pada saluran.

Bedakan ini dengan saluran penimbal dengan kapasiti yang tersedia. Sebuah goroutine boleh menyelesaikan penghantaran ke saluran tanpa menunggu goroutine lain untuk menerima pada saluran.

Contoh di bawah menggambarkan perbezaan antara saluran tidak buffer dan saluran buffer.

sleepRecv := func(c chan int) {
    time.Sleep(time.Second)
    <-c
}

b0 := make(chan int, 0)
go sleepRecv(b0)
start := time.Now()
b0 <- 0                        // must wait for recv in goroutine
fmt.Println(time.Since(start)) // prints 1s

b1 := make(chan int, 1)
go sleepRecv(b1)
start = time.Now()
b1 <- 0                        // does not wait for recv in goroutine
fmt.Println(time.Since(start)) // prints 0s

Atas ialah kandungan terperinci Perlu penjelasan lanjut tentang perbezaan antara saluran tidak buffer (iaitu kapasiti 0) dan saluran buffer kapasiti 1 di Golang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:stackoverflow.com. Jika ada pelanggaran, sila hubungi admin@php.cn Padam