Rumah >pembangunan bahagian belakang >Golang >Cara menggunakan bahasa go untuk melaksanakan fungsi pengkomputeran selari

Cara menggunakan bahasa go untuk melaksanakan fungsi pengkomputeran selari

WBOY
WBOYasal
2023-08-04 11:33:131602semak imbas

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 kira yang mengira jumlah terkumpul daripada 1 kepada nombor tertentu. Kami menggunakan 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.WaitGroupAdd方法逐个添加计算任务,并使用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

Dengan menjalankan kod di atas, kita dapat melihat bahawa output adalah seperti berikut:

rrreee

Dapat dilihat bahawa semua tugas pengkomputeran dilaksanakan secara selari dalam goroutine yang berbeza, dan hasil yang betul diperolehi.

Selain menggunakan kata kunci go 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.
  • Ringkasnya, bahasa Go menyediakan ciri pengaturcaraan serentak yang mudah dan cekap untuk membantu kami mencapai pengkomputeran selari. Dengan mereka bentuk dan mengurus gorouti dengan betul, dan menggunakan primitif serentak yang sesuai, kami boleh melaksanakan pengkomputeran selari dengan mudah dan meningkatkan kecekapan pelaksanaan program.
Rujukan: 🎜🎜🎜Go Corak Concurrency: https://talks.golang.org/2012/concurrency.slide🎜🎜

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!

Kenyataan:
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