Dalam bahasa Go, adalah perkara biasa untuk menggunakan coroutine untuk operasi serentak, tetapi pada masa yang sama, anda juga akan menghadapi beberapa masalah serentak, seperti kebuntuan, keadaan perlumbaan, dsb. Artikel ini akan meneroka sebab masalah konkurensi berlaku apabila program Go dilaksanakan.
1. Punca masalah serentak
Keadaan perlumbaan merujuk kepada apabila berbilang coroutine membaca sumber yang sama pada masa yang sama Keputusan yang tidak dapat diramalkan mungkin berlaku semasa operasi tulis. Keadaan ini sangat biasa dalam bahasa Go Contohnya, berbilang coroutine mengakses pembolehubah yang sama pada masa yang sama, dan mengubah suai nilai pembolehubah boleh menyebabkan ketidakpastian dalam keputusan. Dalam kes ini, kita boleh menggunakan kunci mutex untuk mengelakkan keadaan perlumbaan dan memastikan bahawa hanya satu coroutine mengakses sumber tersebut.
Kebuntuan merujuk kepada situasi di mana berbilang coroutine tidak dapat meneruskan pelaksanaan sementara menunggu satu sama lain melepaskan sumber. Keadaan ini biasanya disebabkan oleh isu peruntukan sumber. Dalam bahasa Go, kita boleh menggunakan saluran untuk menyelaraskan peruntukan sumber antara coroutine untuk mengelakkan kebuntuan.
Apabila atur cara tidak menggunakan mutex dengan betul, masalah konkurensi akan berlaku. Contohnya, apabila berbilang coroutine mengendalikan pembolehubah kongsi yang sama, jika kunci mutex tidak digunakan dengan betul, data mungkin diubah suai beberapa kali atau data mungkin tidak dikemas kini tepat pada masanya. Dalam kes ini, kita perlu meneliti semula logik kod untuk memastikan ketepatan penggunaan mutex.
2. Bagaimana untuk mengelakkan masalah konkurensi
Kunci mutex ialah penyelesaian untuk mengelakkan keadaan perlumbaan dalam bahasa Go . Apabila berbilang coroutine membaca dan menulis pembolehubah kongsi yang sama, kita perlu menggunakan kunci mutex untuk memastikan bahawa hanya satu coroutine boleh mengakses pembolehubah tersebut. Apabila coroutine memperoleh kunci mutex, coroutine lain perlu menunggu coroutine melepaskan kunci sebelum mereka boleh mengaksesnya.
Cara lain untuk mengelakkan isu konkurensi ialah menggunakan saluran. Saluran ialah struktur data khas yang membolehkan penyegerakan dan komunikasi antara coroutine. Apabila berbilang coroutine perlu mengakses sumber yang sama pada masa yang sama, saluran boleh digunakan untuk menyelaraskan urutan akses mereka untuk mengelakkan kebuntuan.
Kod Reentrant merujuk kepada kod yang boleh dilaksanakan dalam berbilang coroutine secara serentak tanpa isu konkurensi. Menulis kod reentrant ialah cara yang berkesan untuk mengelakkan masalah konkurensi. Untuk menulis kod reentrant, kita perlu mempertimbangkan aspek berikut:
(1) Elakkan akses terus kepada pembolehubah global dan sebaliknya gunakan pembolehubah tempatan atau pemalar.
(2) Elakkan menggunakan pembolehubah statik.
(3) Pisahkan pengisytiharan dan permulaan pembolehubah.
(4) Elakkan daripada memanggil kod bukan masuk semula.
3. Ringkasan
Model concurrency bahasa Go menyediakan alat dan rangka kerja yang berkuasa, tetapi ia juga memerlukan kami mempunyai kemahiran dan pengalaman yang lebih tinggi untuk mengelakkan masalah semasa program dijalankan isu. Apabila mengelakkan masalah konkurensi, kita perlu menggunakan kunci mutex, saluran dan menulis kod reentrant untuk mengendalikan penyegerakan dan komunikasi antara coroutine dengan betul. Hanya dengan cara ini seni pengaturcaraan serentak boleh benar-benar direalisasikan dalam bahasa Go.
Atas ialah kandungan terperinci Mengapakah program Go saya mempunyai isu konkurensi semasa pelaksanaan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!