Rumah >pembangunan bahagian belakang >Golang >Apakah perbezaan antara coroutine dan utas dalam bahasa go

Apakah perbezaan antara coroutine dan utas dalam bahasa go

青灯夜游
青灯夜游asal
2023-02-02 18:10:445333semak imbas

Perbezaan: 1. Benang boleh mempunyai berbilang coroutine, dan satu proses juga boleh mempunyai berbilang coroutine sahaja 2. Benang ialah mekanisme penyegerakan, manakala coroutine tidak segerak; daripada panggilan, benang tidak boleh 4. Benang adalah preemptif, dan coroutine bukan preemptif 5. Benang dibahagikan sumber CPU, dan coroutine adalah proses kod yang teratur, dan coroutine memerlukan urutan untuk dihoskan dan dijalankan.

Apakah perbezaan antara coroutine dan utas dalam bahasa go

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

Benang

Urutan merujuk kepada unit pelaksanaan dalam proses dan juga entiti boleh dijadualkan dalam proses. Benang ialah entiti proses dan unit asas penjadualan dan penghantaran CPU Ia adalah unit asas yang lebih kecil daripada proses dan boleh berjalan secara bebas.

Benang itu sendiri pada asasnya tidak memiliki sumber sistem, hanya beberapa sumber yang penting untuk operasi (seperti pembilang program, satu set daftar dan timbunan), tetapi ia boleh dikongsi dengan utas lain yang dimiliki kepada proses yang sama Semua sumber yang dimiliki oleh proses.

Komunikasi antara benang terutamanya melalui memori yang dikongsi dengan pantas dan overhed sumber adalah kurang, berbanding dengan proses, ia tidak cukup stabil dan boleh kehilangan data dengan mudah.

Coroutine

Coroutine ialah urutan ringan dalam mod pengguna dan penjadualan coroutine dikawal sepenuhnya oleh pengguna. Dari sudut pandangan teknikal, "coroutine ialah fungsi yang anda boleh jeda pelaksanaan." Coroutine mempunyai konteks daftar dan tindanan sendiri.

Apabila jadual coroutine ditukar, konteks daftar dan tindanan disimpan ke tempat lain Apabila menukar kembali, konteks daftar dan tindanan yang disimpan sebelum ini dipulihkan secara langsung mengendalikan tindanan pada dasarnya tidak mempunyai overhed penukaran kernel tidak perlu Dikunci akses kepada pembolehubah global, jadi penukaran konteks adalah sangat pantas.

Perbezaan antara coroutine dan thread

Sesuatu benang boleh mempunyai berbilang coroutine dan proses juga boleh mempunyai berbilang coroutine.

Proses benang ialah semua mekanisme segerak, manakala coroutine adalah tak segerak.

Coroutine boleh mengekalkan keadaan panggilan terakhir Setiap kali proses masuk semula, ia bersamaan dengan memasuki keadaan panggilan terakhir.

Thread adalah preemptif, manakala coroutine bukan preemptive, jadi pengguna perlu melepaskan hak penggunaan mereka untuk beralih kepada coroutine lain Oleh itu, hanya satu coroutine yang berhak untuk dijalankan pada masa yang sama, yang bersamaan dengan satu kebolehan.

Coroutine tidak menggantikan benang, tetapi diabstraksikan daripada benang. Benang dibahagikan sumber CPU, dan coroutine adalah proses kod yang teratur memerlukan benang untuk dihoskan dan dijalankan benang atau kumpulan benang, dan boleh menjadi utas semasa, utas UI atau mencipta proses baharu.

Benang adalah sumber coroutine. Coroutine menggunakan sumber benang secara tidak langsung melalui Interceptor.

[Cadangan berkaitan: Pergi tutorial video, Pengajaran pengaturcaraan]

Atas ialah kandungan terperinci Apakah perbezaan antara coroutine dan utas dalam bahasa go. 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:Apa itu golang GobArtikel seterusnya:Apa itu golang Gob