Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Pembangunan Golang: Menguasai pengaturcaraan serentak berdasarkan penghantaran mesej

Pembangunan Golang: Menguasai pengaturcaraan serentak berdasarkan penghantaran mesej

WBOY
WBOYasal
2023-09-20 12:49:58484semak imbas

Pembangunan Golang: Menguasai pengaturcaraan serentak berdasarkan penghantaran mesej

Pembangunan Golang: Menguasai pengaturcaraan serentak berdasarkan penghantaran mesej memerlukan contoh kod khusus

Pengenalan:
Golang, sebagai bahasa pengaturcaraan yang cekap dan ringkas, menyediakan ciri pengaturcaraan serentak yang kaya, antaranya pengaturcaraan serentak berdasarkan penghantaran mesej adalah sebahagian daripada keunikannya. Dalam artikel ini, kami akan membincangkan pengaturcaraan serentak berasaskan penghantaran mesej di Golang secara terperinci dan memberikan contoh kod khusus untuk membantu pembaca memahami dan menguasai teknologi ini dengan lebih baik.

1. Apakah pengaturcaraan serentak berdasarkan penghantaran mesej?
Dalam pengaturcaraan serentak tradisional, rangkaian dalam program menggunakan memori yang dikongsi untuk berkomunikasi, yang boleh membawa kepada masalah seperti kebuntuan dan keadaan perlumbaan dengan mudah. Pengaturcaraan serentak berdasarkan penghantaran mesej menggunakan mesej untuk berkomunikasi antara utas yang berbeza secara relatifnya dan mengelakkan masalah memori yang dikongsi.

Di Golang, pengaturcaraan serentak berdasarkan penghantaran mesej terutamanya bergantung pada goroutine dan saluran. Goroutine ialah benang ringan yang boleh diuruskan oleh penjadual masa jalan Go. Saluran ialah struktur data yang digunakan untuk memindahkan mesej antara goroutine.

2. Gunakan saluran untuk penghantaran mesej
Di Golang, dengan mencipta objek saluran, mesej boleh dihantar antara goroutine yang berbeza. Berikut ialah kod sampel ringkas yang menunjukkan cara menggunakan saluran untuk penghantaran mesej:

func main() {
    // 创建一个int类型的channel
    ch := make(chan int)
    
    // 启动一个goroutine发送消息
    go func() {
        ch <- 1
    }()
    
    // 接收goroutine发送的消息
    num := <-ch
    fmt.Println(num)
}

Dalam contoh di atas, objek saluran jenis int pertama kali dibuat. Seterusnya, gunakan ch dalam goroutine baharu untuk menghantar mesej ke saluran. Akhir sekali, terima mesej daripada saluran melalui kenyataan <code>num := dan cetaknya. <code>ch。接下来,在一个新的goroutine中使用ch 向channel发送消息。最后,通过<code>num := 语句从channel中接收消息,并将其打印出来。

三、channel的阻塞和非阻塞操作
在使用channel进行消息传递时,有两种基本的操作方式:阻塞和非阻塞。

阻塞操作是指当channel中没有消息可用时,接收操作会一直阻塞,直到有消息可用。同样地,发送操作也会阻塞直到有接收者接收消息。

非阻塞操作是指当channel中没有消息可用时,接收操作会立即返回一个空值。发送操作则会在channel已满时立即返回一个错误。

下面是一个示例代码,展示了如何使用阻塞和非阻塞操作:

func main() {
    ch := make(chan int, 1)
    ch <- 1 // 向channel发送消息
    
    // 阻塞操作
    num := <-ch
    fmt.Println(num)
    
    // 非阻塞操作
    select {
    case num := <-ch:
        fmt.Println(num)
    default:
        fmt.Println("channel中没有消息可用")
    }
}

在上述示例中,首先创建了一个有缓冲区大小为1的channel对象,并向其发送了一个消息。接下来,通过接收操作和非阻塞的选择语句来展示阻塞和非阻塞操作的效果。

四、使用select语句进行多路复用
Golang中的select语句提供了一种方式,可以从多个channel中选择一个可用的channel进行操作。下面是一个示例代码,展示了如何使用select语句进行多路复用:

func main() {
    ch1 := make(chan int)
    ch2 := make(chan int)
    
    go func() {
        ch1 <- 1
    }()
    
    go func() {
        ch2 <- 2
    }()
    
    // 使用select语句选择可用的channel
    select {
    case num := <-ch1:
        fmt.Println(num)
    case num := <-ch2:
        fmt.Println(num)
    }
}

在上述示例中,首先创建了两个不同的channel对象ch1ch2。然后分别向ch1ch2

3. Operasi menyekat dan tidak menyekat saluran

Apabila menggunakan saluran untuk penghantaran mesej, terdapat dua kaedah operasi asas: menyekat dan tidak menyekat.

Operasi menyekat bermakna apabila tiada mesej tersedia dalam saluran, operasi penerimaan akan menyekat sehingga mesej tersedia. Begitu juga, hantar blok operasi sehingga penerima menerima mesej.

Operasi tanpa sekatan bermakna apabila tiada mesej tersedia dalam saluran, operasi penerimaan akan segera mengembalikan nilai nol. Operasi hantar akan mengembalikan ralat serta-merta apabila saluran penuh.

Berikut ialah contoh kod yang menunjukkan cara menggunakan operasi menyekat dan tidak menyekat:
    rrreee
  1. Dalam contoh di atas, objek saluran dengan saiz penimbal 1 mula-mula dibuat dan mesej dihantar kepadanya. Seterusnya, kesan operasi menyekat dan tidak menyekat ditunjukkan melalui operasi terima dan penyataan pilih tanpa sekatan.
  2. 4. Gunakan penyata pilih untuk pemultipleksan
  3. Penyataan pilih di Golang menyediakan cara untuk memilih saluran yang tersedia daripada berbilang saluran untuk operasi. Di bawah ialah contoh kod yang menunjukkan cara menggunakan penyata terpilih untuk pemultipleksan:
rrreee🎜Dalam contoh di atas, dua objek saluran berbeza ch1 dan ch2 pertama kali dibuat kod>. Kemudian hantar mesej ke ch1 dan ch2 masing-masing. Akhir sekali, pilih saluran yang tersedia dengan menggunakan pernyataan pilih dan cetak mesej yang sepadan. 🎜🎜5. Ringkasan🎜Artikel ini memperkenalkan konsep dan ciri pengaturcaraan serentak berdasarkan penghantaran mesej dalam Golang, dan memberikan contoh kod khusus. Dengan menggunakan goroutin dan saluran untuk melaksanakan penghantaran mesej, operasi serentak yang agak bebas dicapai antara berbilang goroutin. Pada masa yang sama, melalui penggunaan operasi menyekat dan tidak menyekat serta penyataan pilih, fleksibiliti dan kebolehselenggaraan pengaturcaraan serentak dipertingkatkan lagi. 🎜🎜Saya berharap melalui pengenalan artikel ini, pembaca dapat lebih memahami dan menguasai pengaturcaraan serentak berasaskan hantaran mesej di Golang, memberikan permainan sepenuhnya kepada kelebihan pengaturcaraan serentak Golang, dan meningkatkan prestasi dan kebolehpercayaan program. 🎜🎜Bahan rujukan: 🎜🎜🎜Dokumentasi rasmi Golang (https://golang.org/doc/) 🎜🎜Pergi latihan pengaturcaraan serentak (https://www.imooc.com/learn/927)🎜🎜

Atas ialah kandungan terperinci Pembangunan Golang: Menguasai pengaturcaraan serentak berdasarkan penghantaran mesej. 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