Rumah >pembangunan bahagian belakang >Golang >Apakah sebab mengapa bahasa go menyokong konkurensi tinggi?

Apakah sebab mengapa bahasa go menyokong konkurensi tinggi?

青灯夜游
青灯夜游asal
2022-12-20 10:31:385829semak imbas

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.

Apakah sebab mengapa bahasa go menyokong konkurensi tinggi?

Persekitaran pengendalian tutorial ini: sistem Windows 7, GO versi 1.18, komputer Dell G3.

Lagenda go

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.

Concurrency in go

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:

  1. Ruang pengguna mengelakkan kos yang disebabkan oleh pertukaran antara mod kernel dan mod pengguna >
  2. boleh Penjadualan pada lapisan bahasa dan rangka kerja
  3. Ruang tindanan yang lebih kecil membolehkan penciptaan sejumlah besar kejadian

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.

Ringkasan

Golang melaksanakan model konkurensi CSP sebagai asas untuk konkurensi Lapisan bawah menggunakan goroutine sebagai entiti serentak ringan. Cipta ratusan ribu entiti. Pemesejan tanpa nama berterusan antara entiti melalui saluran memisahkan mereka, dan merealisasikan penjadualan automatik pada peringkat bahasa Ini melindungi banyak butiran dalaman dan menyediakan kata kunci sintaks yang mudah kepada dunia luar, yang sangat memudahkan transformasi pemikiran pengaturcaraan serentak dan kerumitan mengurus utas. .

Ringkasan satu ayat: Bahasa Go melaksanakan pembangunan berbilang coroutine dari peringkat kata kunci semasa reka bentuk, seolah-olah bahasa itu sememangnya menyokong konkurensi tinggi.

[Cadangan berkaitan:

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!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel sebelumnya:Adakah pergi bahasa?Artikel seterusnya:Adakah pergi bahasa?