Rumah > Artikel > pembangunan bahagian belakang > Cara menggunakan bahasa go untuk melaksanakan fungsi pengkomputeran selari
Cara menggunakan bahasa Go untuk melaksanakan fungsi pengkomputeran selari
Bahasa Go ialah bahasa pengaturcaraan yang cekap dan serentak, terutamanya sesuai untuk tugas pengkomputeran selari. Dalam artikel ini, kami akan memperkenalkan cara menggunakan bahasa Go untuk melaksanakan fungsi pengkomputeran selari dan menyediakan contoh kod yang berkaitan.
Pengkomputeran selari adalah untuk membahagikan tugas besar kepada beberapa tugas kecil, yang dilaksanakan serentak pada berbilang pemproses untuk meningkatkan kecekapan pengkomputeran. Bahasa Go menyediakan banyak ciri pengaturcaraan serentak, menjadikannya agak mudah untuk melaksanakan pengkomputeran selari. Di bawah ialah contoh yang menunjukkan cara melaksanakan pengkomputeran selari menggunakan bahasa Go.
package main import ( "fmt" "sync" ) func calculate(num int, wg *sync.WaitGroup) { defer wg.Done() result := 0 for i := 1; i <= num; i++ { result += i } fmt.Printf("Sum of numbers from 1 to %d is %d ", num, result) } func main() { wg := &sync.WaitGroup{} numbers := []int{10, 20, 30, 40, 50} for _, num := range numbers { wg.Add(1) go calculate(num, wg) } wg.Wait() fmt.Println("All calculations are done.") }
Dalam contoh ini, kami mentakrifkan fungsi sync.WaitGroup
untuk menunggu semua tugasan pengkomputeran serentak selesai. Dalam fungsi utama
, kami mencipta kepingan nombor
yang mengandungi nombor yang kami perlukan untuk mengira jumlah kumulatif. Kemudian, kami menggunakan kaedah Tambah
sync.WaitGroup
untuk menambah tugas pengiraan satu demi satu dan menggunakan kata kunci go
untuk melakukan pengiraan secara serentak dalam goroutine yang berbeza. Akhir sekali, kami memanggil kaedah Tunggu
untuk menunggu semua tugas pengiraan selesai dan menghasilkan keputusan akhir. calculate
函数,用于计算从1到给定数字的累加和。我们使用sync.WaitGroup
来等待所有并发计算任务完成。在main
函数中,我们创建了一个切片numbers
,其中包含了需要计算累加和的数字。然后,我们使用sync.WaitGroup
的Add
方法逐个添加计算任务,并使用go
关键字在不同的goroutine中并发执行计算。最后,我们调用Wait
方法等待所有计算任务完成,并输出最终结果。
通过运行上述代码,我们可以看到输出结果如下:
Sum of numbers from 1 to 10 is 55 Sum of numbers from 1 to 30 is 465 Sum of numbers from 1 to 40 is 820 Sum of numbers from 1 to 20 is 210 Sum of numbers from 1 to 50 is 1275 All calculations are done.
可以看到,所有计算任务都在不同的goroutine中并行执行,并且得到了正确的结果。
除了使用go
rrreee
Dapat dilihat bahawa semua tugas pengkomputeran dilaksanakan secara selari dalam goroutine yang berbeza, dan hasil yang betul diperolehi. Selain menggunakan kata kuncigo
untuk mencipta tugasan pelaksanaan serentak goroutine, bahasa Go juga menyediakan primitif serentak yang kaya, seperti mutex (Mutex), pembolehubah keadaan (Keadaan) dan saluran (Saluran) dsb., untuk membantu melaksanakan logik pengkomputeran selari yang lebih kompleks. Dalam aplikasi praktikal, kami boleh menggunakan pengkomputeran selari untuk beberapa tugas yang memerlukan sejumlah besar pengiraan, seperti pemprosesan data, pemprosesan imej, analisis data besar, dsb. Dengan membahagikan tugas kepada berbilang subtugas dan melaksanakannya secara serentak pada berbilang pemproses, kami boleh meningkatkan kecekapan dan prestasi pengiraan dengan banyak. Atas ialah kandungan terperinci Cara menggunakan bahasa go untuk melaksanakan fungsi pengkomputeran selari. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!