Sebab: Bahasa Go melaksanakan pembangunan berbilang coroutine dari peringkat kata kunci semasa reka bentuk. Bahasa go melaksanakan model concurrency CSP sebagai asas untuk concurrency Lapisan bawah menggunakan goroutine sebagai entiti serentak adalah sangat ringan dan boleh membuat ratusan ribu entiti meneruskan pemesejan tanpa nama, iaitu dilaksanakan pada peringkat bahasa. Penjadualan automatik dilaksanakan, yang melindungi banyak butiran dalaman dan menyediakan kata kunci sintaks mudah kepada dunia luar, yang sangat memudahkan transformasi pemikiran pengaturcaraan serentak dan kerumitan mengurus benang.
Persekitaran pengendalian tutorial ini: sistem Windows 7, GO versi 1.18, komputer Dell G3.
Terdapat banyak legenda tentang Go dalam pasaran, "Ia secara semula jadi menyokong konkurensi tinggi, kelajuan pelaksanaannya hampir kepada C, dan perkhidmatan rangkaian Dekat dengan Nginx…”. Segala-galanya baik-baik saja, tetapi satu-satunya perkara yang sukar difahami ialah "secara semula jadi menyokong konkurensi tinggi", terutamanya perkataan "semula jadi", yang benar-benar membuatkan orang berasa penuh dengan mewah dan misteri.
Mula-mula kita lihat betapa mudahnya untuk melaksanakan operasi serentak dalam go. Mari lihat kod:
func main() { go add(3,6) go add(1,6) time.Sleep(time.Second)}func add(a int,b int) { result := a+b fmt.Println(result)}
Kata kunci go melaksanakan panggilan pembukaan coroutine 't tunggu, Apabila benang utama tamat, coroutine akan tamat serta-merta.
Malah, goroutine dalam bahasa go ialah model rujukan (Communicating Sequential Process), yang terdapat dalam saluran dalam Tugasan CSP asal dilaksanakan serta-merta, dan bahasa Go menambah cache, iaitu, tugasan boleh disimpan sementara dan kemudian dilaksanakan satu demi satu dalam urutan apabila proses pelaksanaan sudah sedia.
Tetapi sebenarnya, bahasa Go tidak melaksanakan sepenuhnya semua teori model CSP, tetapi hanya meminjam dua konsep proses dan saluran. Prestasi proses dalam bahasa Go ialah goroutine ialah entiti yang sebenarnya dilaksanakan secara serentak Perkongsian data dicapai antara setiap entiti melalui komunikasi saluran.
1) goroutine
Goroutine ialah entiti pelaksanaan serentak yang sebenar bagi go. Lapisan bawahnya ialah menggunakan coroutine untuk mencapai konkurensi Untuk urutan pengguna, titik permulaan untuk lapisan bawah Go untuk menggunakan coroutine adalah kerana ia mempunyai ciri-ciri berikut:
2) saluran
digunakan dalam saluran go dalam CSP. Saluran dibuat secara berasingan dan boleh dihantar antara proses Mod komunikasinya adalah serupa dengan mod bos-pekerja Entiti menghantar mesej kepada saluran dan kemudian mendengar pemprosesan entiti tersebut Tanpa nama, ini mencapai penyahgandingan antara entiti Saluran adalah segerak dan mesej dihantar ke saluran itu akhirnya mesti digunakan oleh entiti lain, ia sebenarnya adalah barisan mesej yang menyekat.3) Penjadual
goroutine menyediakan penjadual pada tahap golang Algoritma kerja mencuri ditambahkan pada penjadual boleh didahulukan secara tidak segerak, jadi tidak ada Gelung dalam fungsi memanggil penjadual tidak lagi menemui jalan buntu atau melambatkan pengumpulan sampah dengan ketara. Di samping itu, go merangkum perpustakaan IO rangkaian, melindungi butiran kompleks, menyediakan sokongan kata kunci sintaks bersatu kepada dunia luar dan memudahkan kos menulis program serentak.Pergi tutorial video, Pengajaran pengaturcaraan]
Atas ialah kandungan terperinci Apakah sebab mengapa bahasa go menyokong konkurensi tinggi?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!