Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Laksanakan pengaturcaraan serentak Select Channels Go melalui golang

Laksanakan pengaturcaraan serentak Select Channels Go melalui golang

WBOY
WBOYasal
2023-09-29 12:24:35851semak imbas

通过golang实现高效的Select Channels Go并发式编程

Saluran Pilihan yang Cekap Pergi pengaturcaraan serentak melalui Golang

Pengenalan:
Dalam pembangunan perisian hari ini, pengaturcaraan serentak telah menjadi keperluan biasa. Pengaturcaraan serentak membolehkan kami menggunakan sepenuhnya pemproses berbilang teras, dengan itu meningkatkan prestasi dan kecekapan program. Salah satu ciri Golang ialah ia menyediakan sokongan kuat untuk pengaturcaraan serentak, yang mana Saluran adalah bahagian penting dalam pengaturcaraan serentak di Golang. Artikel ini akan memperkenalkan cara menggunakan pernyataan Pilih dan Saluran di Golang untuk mencapai pengaturcaraan serentak yang cekap dan memberikan contoh kod khusus.

  1. Saluran dan penyataan Pilih dalam Golang
    Saluran ialah mekanisme yang digunakan untuk berkomunikasi antara proses Go yang berbeza. Ia menyediakan dua operasi asas: hantar dan terima. Data dihantar ke Saluran melalui operasi hantar, dan data dibawa keluar dari Saluran melalui operasi terima. Pernyataan Pilih dalam Golang digunakan untuk memilih antara berbilang Saluran (iaitu, menerima data tanpa menyekat), dengan itu mencapai pengaturcaraan serentak.
  2. Gunakan pernyataan Pilih untuk pengaturcaraan serentak
    Berikut ialah langkah asas untuk menggunakan pernyataan Pilih untuk pengaturcaraan serentak:

Langkah 1: Cipta Saluran yang memerlukan interaksi
Pertama, kita perlu mencipta Saluran yang memerlukan interaksi. Anda boleh menggunakan fungsi make() untuk mencipta Saluran.

c := make(chan int)

Langkah 2: Cipta Goroutine dan berkomunikasi melalui Saluran
Kemudian, kita boleh mencipta berbilang Goroutine dan menyampaikan data melalui Saluran. Dalam goroutine, kita boleh menggunakan gelung tak terhingga untuk menghantar data secara berterusan.

go func() {
    for {
        c <- 1 // 发送数据到Channel
    }
}()

Langkah 3: Gunakan pernyataan Pilih untuk pemilihan data
Akhir sekali, kita boleh menggunakan pernyataan Pilih untuk memilih Saluran yang perlu menerima data dan memproses data di dalamnya.

for {
    select {
        case <-c:
            // 处理接收到的数据
    }
}
  1. Contoh: Kira jumlah tugas serentak
    Di bawah kami menggunakan contoh kod khusus untuk menunjukkan cara menggunakan penyataan Saluran dan Pilih untuk melaksanakan pengaturcaraan serentak. Kami akan mengira jumlah siri nombor, mengagihkan tugas kepada berbilang goroutine dan menggunakan Saluran untuk berkomunikasi.

pakej utama

import "fmt"

func calculateSum(nombor []int, c chan int) {

sum := 0
for _, num := range numbers {
    sum += num
}
c <- sum

}

func main() {

numbers := []int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
workerCount := 5
c := make(chan int)

for i := 0; i < workerCount; i++ {
    go calculateSum(numbers[i*2:i*2+2], c)
}

totalSum := 0
for i := 0; i < workerCount; i++ {
    totalSum += <-c
}

fmt.Println("Total Sum:", totalSum)

}🜎 pertama kod di atas Fungsi calculateSum() ditakrifkan untuk mengira jumlah sebahagian daripada nombor dalam tatasusunan dan menghantar hasilnya melalui Saluran. Kemudian, kami mencipta tatasusunan 10 nombor dan menentukan bilangan goroutine untuk digunakan. Seterusnya, kami mencipta Saluran c dan menggunakan goroutine untuk menetapkan tugasan kepada Goroutine yang berbeza. Akhir sekali, kami menerima data daripada Saluran menggunakan pernyataan Pilih melalui gelung untuk dan mengira jumlah tatasusunan. Akhirnya, kami mencetak hasilnya.

Kesimpulan:

Dengan menggunakan pernyataan Pilih dan Saluran di Golang, kita boleh mencapai pengaturcaraan serentak yang cekap. Model pengaturcaraan serentak ini membolehkan penggunaan pemproses berbilang teras yang lebih baik dan meningkatkan prestasi dan kecekapan program. Artikel ini memperkenalkan cara menggunakan penyataan Saluran dan Pilih dalam Golang untuk pengaturcaraan serentak dan menyediakan contoh kod khusus. Pembaca boleh mengubah suai kod mengikut keperluan mereka sendiri dan menerokai dunia pengaturcaraan serentak Golang.

Atas ialah kandungan terperinci Laksanakan pengaturcaraan serentak Select Channels Go melalui golang. 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