Rumah pembangunan bahagian belakang Golang Apakah perbezaan antara concurrency dan paralelisme dalam Go

Apakah perbezaan antara concurrency dan paralelisme dalam Go

Jan 10, 2023 pm 06:13 PM
golang pergi bahasa

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.

Apakah perbezaan antara concurrency dan paralelisme dalam Go

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.

Apakah perbezaan antara concurrency dan paralelisme dalam Go
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!

Kenyataan Laman Web ini
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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Perpustakaan apa yang digunakan untuk operasi nombor terapung di GO? Perpustakaan apa yang digunakan untuk operasi nombor terapung di GO? Apr 02, 2025 pm 02:06 PM

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

Apakah masalah dengan thread giliran di crawler colly go? Apakah masalah dengan thread giliran di crawler colly go? Apr 02, 2025 pm 02:09 PM

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. � ...

Di Go, mengapa rentetan percetakan dengan fungsi println dan rentetan () mempunyai kesan yang berbeza? Di Go, mengapa rentetan percetakan dengan fungsi println dan rentetan () mempunyai kesan yang berbeza? Apr 02, 2025 pm 02:03 PM

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

Bagaimana menyelesaikan masalah penukaran jenis user_id semasa menggunakan aliran redis untuk melaksanakan beratur mesej dalam bahasa Go? Bagaimana menyelesaikan masalah penukaran jenis user_id semasa menggunakan aliran redis untuk melaksanakan beratur mesej dalam bahasa Go? Apr 02, 2025 pm 04:54 PM

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

Perpustakaan mana yang dibangunkan oleh syarikat besar atau disediakan oleh projek sumber terbuka yang terkenal? Perpustakaan mana yang dibangunkan oleh syarikat besar atau disediakan oleh projek sumber terbuka yang terkenal? Apr 02, 2025 pm 04:12 PM

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? Apa yang perlu saya lakukan jika label struktur tersuai di Goland tidak dipaparkan? Apr 02, 2025 pm 05:09 PM

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 ...

Tujuan Golang: Membina sistem yang cekap dan berskala Tujuan Golang: Membina sistem yang cekap dan berskala Apr 09, 2025 pm 05:17 PM

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.

Bagaimana untuk menyelesaikan masalah kekangan jenis fungsi generik Golang yang dipadamkan secara automatik dalam vscode? Bagaimana untuk menyelesaikan masalah kekangan jenis fungsi generik Golang yang dipadamkan secara automatik dalam vscode? Apr 02, 2025 pm 02:15 PM

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

See all articles