


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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Perpustakaan yang digunakan untuk operasi nombor terapung dalam bahasa Go memperkenalkan cara memastikan ketepatannya ...

Masalah Threading Giliran di GO Crawler Colly meneroka masalah menggunakan Perpustakaan Colly Crawler dalam bahasa Go, pemaju sering menghadapi masalah dengan benang dan permintaan beratur. � ...

Perbezaan antara percetakan rentetan dalam bahasa Go: perbezaan kesan menggunakan fungsi println dan rentetan () sedang ...

Masalah menggunakan redisstream untuk melaksanakan beratur mesej dalam bahasa Go menggunakan bahasa Go dan redis ...

Perpustakaan mana yang dibangunkan oleh syarikat besar atau projek sumber terbuka yang terkenal? Semasa pengaturcaraan di GO, pemaju sering menghadapi beberapa keperluan biasa, ...

Apa yang perlu saya lakukan jika label struktur tersuai di Goland tidak dipaparkan? Apabila menggunakan Goland untuk Pembangunan Bahasa GO, banyak pemaju akan menghadapi tag struktur tersuai ...

Pergi bahasa berfungsi dengan baik dalam membina sistem yang cekap dan berskala. Kelebihannya termasuk: 1. Prestasi Tinggi: Disusun ke dalam Kod Mesin, Kelajuan Berjalan Cepat; 2. Pengaturcaraan serentak: Memudahkan multitasking melalui goroutine dan saluran; 3. Kesederhanaan: sintaks ringkas, mengurangkan kos pembelajaran dan penyelenggaraan; 4. Cross-Platform: Menyokong kompilasi silang platform, penggunaan mudah.

Penghapusan automatik Golang Generik Jenis Kekangan Jenis dalam Pengguna VSCode mungkin menghadapi masalah yang aneh ketika menulis kod Golang menggunakan vscode. Bila ...
