Rumah >pembangunan bahagian belakang >Golang >Apakah perbezaan antara concurrency dan paralelisme dalam Go
Perbezaan antara concurrency dan parallelism: 1. Concurrency adalah untuk menyerahkan tugas kepada pemproses untuk diproses pada titik masa yang berbeza, manakala parallelism adalah untuk menetapkan setiap tugas kepada setiap pemproses untuk penyiapan bebas; masa yang sama, tugasan tidak akan berjalan pada masa yang sama, tetapi secara selari, pada masa yang sama, tugasan mesti dijalankan pada masa yang sama.
Persekitaran pengendalian tutorial ini: sistem Windows 7, GO versi 1.18, komputer Dell G3.
Apabila memahami konsep konkurensi, sentiasa ada konsep selari lain yang terlibat. Mari kita fahami perbezaan antara concurrency dan parallelism.
Concurrency : Mengendalikan tugas kepada pemproses untuk diproses pada titik masa yang berbeza. Pada masa yang sama, tugas tidak berjalan pada masa yang sama.
Paralelisme : Berikan setiap tugasan kepada setiap pemproses untuk diselesaikan secara berasingan. Pada masa yang sama, tugas mesti dijalankan pada masa yang sama.
Konkurensi bukan selari. Paralelisme mempunyai kepingan kod yang berbeza yang dilaksanakan pada pemproses fizikal yang berbeza pada masa yang sama. Kunci kepada keselarian adalah melakukan banyak perkara pada masa yang sama, dan concurrency merujuk kepada mengurus banyak perkara pada masa yang sama Perkara ini hanya boleh dilakukan separuh jalan sebelum dijeda untuk melakukan perkara lain.
Dalam banyak kes, concurrency adalah lebih baik daripada paralelisme, kerana jumlah sumber sistem pengendalian dan perkakasan secara amnya kecil, tetapi mereka boleh menyokong sistem untuk melakukan banyak perkara pada masa yang sama. Falsafah "melakukan lebih banyak dengan sumber yang lebih sedikit" ini juga merupakan falsafah yang membimbing reka bentuk bahasa Go.
Jika anda ingin membuat goroutine selari, anda mesti menggunakan lebih daripada satu pemproses logik. Apabila terdapat berbilang pemproses logik, penjadual akan mengedarkan gorout secara sama rata kepada setiap pemproses logik. Ini akan menyebabkan goroutine berjalan pada benang yang berbeza. Walau bagaimanapun, untuk benar-benar mencapai keselarian, pengguna perlu menjalankan program mereka pada mesin dengan berbilang pemproses fizikal. Jika tidak, walaupun bahasa Go menggunakan berbilang utas semasa berjalan, goroutine masih akan berjalan serentak pada pemproses fizikal yang sama dan kesan selari tidak akan dicapai.
Rajah berikut menunjukkan perbezaan antara menjalankan gorout secara serentak pada satu pemproses logik dan menjalankan dua gorout serentak secara selari pada dua pemproses logik. Penjadual mengandungi beberapa algoritma pintar yang akan dikemas kini dan dipertingkatkan dengan keluaran bahasa Go, jadi tidak disyorkan untuk mengubah suai tetapan lalai secara membuta tuli untuk pemproses logik semasa masa jalan bahasa. Jika anda benar-benar berfikir bahawa mengubah suai bilangan pemproses logik akan meningkatkan prestasi, anda juga boleh membuat pelarasan kecil pada parameter masa jalan bahasa.
Rajah: Perbezaan antara konkurensi dan selari
Bahasa Go boleh mencapai pelaksanaan selari apabila bilangan GOMAXPROCS adalah sama dengan bilangan tugasan, tetapi secara umum ia adalah dilaksanakan serentak.
[Cadangan berkaitan: Pergi tutorial video, Pengajaran pengaturcaraan]
Atas ialah kandungan terperinci Apakah perbezaan antara concurrency dan paralelisme dalam Go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!