Paralelisme dalam Go: Goroutines dan GoMaxProcs
Dalam Go, keupayaan untuk melaksanakan berbilang tugas secara serentak dicapai melalui goroutine. Dalam kod yang diberikan, tiga goroutine dihasilkan menggunakan pernyataan go f(i). Goroutine ini berjalan serentak dengan fungsi utama, membenarkan berbilang tugasan dilaksanakan secara selari.
Untuk memastikan fungsi utama tidak terkeluar sebelum goroutine selesai, fungsi Scanln digunakan untuk menunggu input pengguna. Walau bagaimanapun, lebih baik berlatih menggunakan penyegerakan.WaitGroup untuk menunggu semua gorout selesai sebelum keluar daripada fungsi utama.
Fungsi dowork mensimulasikan kerja dengan tidur selama 5 saat. Memandangkan ia dipanggil dalam goroutine, ia akan berjalan serentak dengan panggilan goroutine lain. Walau bagaimanapun, susunan fungsi dowork akan dilaksanakan tidak bersifat deterministik dan bergantung pada faktor seperti perkakasan asas dan penjadualan sistem pengendalian.
GoMaxProcs ialah pembolehubah persekitaran yang mengawal bilangan maksimum urutan OS serentak yang digunakan oleh masa jalanan Go. Secara lalai, Go menetapkan GOMAXPROCS kepada bilangan CPU yang tersedia pada sistem. Nilai ini boleh diubah suai untuk mengoptimumkan gelagat konkurensi program Go.
Dalam kod yang diberikan, menggunakan goroutine untuk melaksanakan fungsi dowork ialah pendekatan yang sah untuk mencapai keselarian. Walau bagaimanapun, jika anda memerlukan lebih kawalan ke atas keselarian dan susunan pelaksanaan tugas, anda boleh mempertimbangkan untuk menggunakan saluran dan pekerja berasingan yang khusus untuk melaksanakan fungsi dowork. Pendekatan ini memberikan lebih fleksibiliti dan membolehkan pengurusan konkurensi yang lebih diperhalusi.
Selain itu, terdapat fungsi utiliti dan perpustakaan yang tersedia, seperti fungsi Parallelize yang disebut dalam jawapan yang disediakan, yang boleh membantu menyelaraskan penyelarasan tugas dalam Go. Utiliti ini boleh menyediakan cara yang mudah dan cekap untuk melaksanakan pemprosesan selari dalam kod anda.
Atas ialah kandungan terperinci Cara Mencapai Paralelisme dalam Go: Goroutines, GoMaxProcs dan Bila Perlu Pertimbangkan Saluran?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!