Rumah > pembangunan bahagian belakang > Golang > Panduan pengaturcaraan serentak bahasa Go

Panduan pengaturcaraan serentak bahasa Go

王林
Lepaskan: 2024-03-27 18:30:05
asal
487 orang telah melayarinya

Panduan pengaturcaraan serentak bahasa Go

Go ialah bahasa pengaturcaraan sumber terbuka yang direka untuk membina perisian yang mudah, boleh dipercayai dan cekap. Salah satu ciri yang paling ketara ialah keupayaan pengaturcaraan serentak yang berkuasa. Melalui ciri konkurensi bahasa Go, pemproses berbilang teras boleh digunakan dengan lebih baik untuk mencapai pemprosesan selari yang cekap dan meningkatkan prestasi dan kelajuan program.

Dalam bahasa Go, melaksanakan pengaturcaraan serentak bergantung terutamanya pada goroutine dan saluran. Goroutine ialah utas ringan dalam bahasa Go yang boleh membuat dan mengurus sejumlah besar tugas serentak dengan mudah. Saluran ialah saluran paip yang digunakan untuk komunikasi dan pemindahan data antara goroutine.

Yang berikut akan menggunakan beberapa contoh kod khusus untuk menunjukkan cara menggunakan goroutine dan saluran untuk melaksanakan pengaturcaraan serentak dalam bahasa Go.

1. Gunakan goroutine untuk mencipta tugasan serentak

package main

import (
    "fmt"
    "time"
)

func task(id int) {
    for i := 0; i < 5; i++ {
        fmt.Printf("Task %d: %d
", id, i)
        time.Sleep(time.Second)
    }
}

func main() {
    for i := 0; i < 3; i++ {
        go task(i)
    }
    time.Sleep(6 * time.Second) // 等待所有goroutine执行完毕
}
Salin selepas log masuk

Dalam kod di atas, 3 goroutine dicipta melalui penyataan go task(i) untuk melaksanakan fungsi task di pada masa yang sama. Setiap goroutine akan mengeluarkan status pelaksanaan 5 tugasan dan menunggu semua goroutine menyelesaikan pelaksanaan melalui time.Sleep. go task(i)语句创建了3个goroutine来同时执行task函数,每个goroutine都会输出5次任务的执行情况,通过time.Sleep来等待所有goroutine执行完毕。

2. 使用channel进行数据交互

package main

import "fmt"

func producer(ch chan int) {
    for i := 0; i < 5; i++ {
        ch <- i
    }
    close(ch) // 关闭channel
}

func consumer(ch chan int) {
    for {
        val, ok := <-ch
        if !ok {
            break
        }
        fmt.Printf("Received: %d
", val)
    }
}

func main() {
    ch := make(chan int)
    go producer(ch)
    go consumer(ch)
    select {} // 阻塞主goroutine
}
Salin selepas log masuk

在上面的代码中,通过producer函数向channel发送数据,通过consumer函数从channel接收数据,通过close(ch)来关闭channel。通过select {}

2. Gunakan saluran untuk interaksi data

rrreee

Dalam kod di atas, data dihantar ke saluran melalui fungsi pengeluar, data diterima daripada saluran melalui pengguna fungsi, dan data diterima daripada saluran melalui fungsi producer code>close(ch) untuk menutup saluran. Gunakan pernyataan select {} untuk menyekat goroutine utama supaya atur cara boleh terus berjalan sehingga semua tugasan selesai. 🎜🎜Melalui contoh kod ringkas di atas, anda dapat melihat bahawa bahasa Go menyediakan sokongan pengaturcaraan serentak yang kuat melalui goroutine dan saluran, dan boleh melaksanakan pelaksanaan selari tugas serentak, penghantaran data dan komunikasi dengan mudah. Bagi pembangun yang ingin mengetahui lebih lanjut tentang pengaturcaraan serentak, menguasai kemahiran pengaturcaraan serentak bahasa Go akan menjadi cara yang baik untuk meningkatkan kemahiran dan belajar mereka. 🎜

Atas ialah kandungan terperinci Panduan pengaturcaraan serentak bahasa Go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan