Pembentangan Google I/O 2012 "Go Concurrency Patterns" menimbulkan persoalan sama ada goroutine, benang ringan dalam bahasa Go , dilaksanakan sebagai coroutine.
Definisi Coroutine dan Perbandingan
Coroutine biasanya membayangkan mekanisme pemindahan kawalan yang jelas antara coroutine yang berbeza. Pengaturcara boleh menentukan secara pengaturcaraan bila coroutine harus menggantung pelaksanaan dan memberikan kawalan kepada yang lain.
Pelaksanaan Goroutine
Ambil goroutine, sebaliknya, secara tersirat menyerahkan kawalan pada yang spesifik tetapi akhirnya tidak tentu mata. Sebagai contoh, goroutine digantung sebelum melaksanakan operasi I/O atau menghantar data melalui saluran. Pendekatan ini membolehkan pengaturcara menulis proses berurutan dan ringan yang berkongsi keadaan secara berkesan.
Butiran Pelaksanaan
Pelaksanaan goroutine adalah serupa dengan perpustakaan "State Threads", yang beroperasi pada tahap yang lebih rendah. Go berinteraksi secara langsung dengan kernel OS tanpa bergantung pada perpustakaan luaran.
Kemas kini: Cadangan Pakej Coroutine
Pada tahun 2023, Russ Cox mencadangkan pakej coroutine standard untuk Go, menawarkan rangka kerja untuk pemindahan kawalan eksplisit dan koperasi penjadualan.
Nota Tambahan
Sebelum Go 1.14, goroutine dijadualkan bukan preemptive, di mana kernel boleh menggantung benang pada bila-bila masa. Sejak Go 1.14, gorouti telah dijadualkan (hampir) secara awalan, membolehkan kawalan yang lebih terperinci ke atas pelaksanaannya.
Atas ialah kandungan terperinci Adakah Go Goroutines Benar Coroutines?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!