Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Eksplorasi Pengaturcaraan Serentak Golang: Membongkar Misteri Goroutines

Eksplorasi Pengaturcaraan Serentak Golang: Membongkar Misteri Goroutines

PHPz
PHPzasal
2023-07-18 16:03:24605semak imbas

Penerokaan Pengaturcaraan Serentak Golang: Membongkar Misteri Goroutines

Golang ialah bahasa pengaturcaraan sumber terbuka yang terkenal dengan keupayaan pengaturcaraan serentak yang berkuasa. Model konkurensinya didorong oleh konsep yang dipanggil Goroutines, membolehkan pembangun memanfaatkan pemproses berbilang teras dengan mudah. Dalam artikel ini, kami akan meneroka model pengaturcaraan serentak Golang dan menyahmistifikasi Goroutines melalui contoh kod.

Di Golang, Goroutines ialah utas ringan yang diuruskan oleh sistem masa jalan bahasa Go. Goroutines boleh melaksanakan berbilang tugas serentak dalam program tanpa menyekat utas utama. Ini membolehkan pembangun menggunakan sumber CPU dengan cekap secara serentak.

Mari kita mulakan dengan contoh program yang mudah. Katakan kita mempunyai senarai tugas dan perlu melaksanakan setiap tugas secara serentak. Kita boleh menggunakan Goroutines untuk mencapai ini. Berikut ialah contoh kod ringkas:

package main

import (
    "fmt"
)

func doTask(task string) {
    // 模拟执行任务
    fmt.Printf("正在执行任务:%s
", task)
}

func main() {
    tasks := []string{"任务1", "任务2", "任务3"}
    for _, task := range tasks {
        go doTask(task)
    }

    // 等待所有任务完成
    var input string
    fmt.Scanln(&input)
}

Dalam kod di atas, kami mentakrifkan fungsi doTask, yang mensimulasikan pelaksanaan tugas. Dalam fungsi utama, kami membuat senarai tugasan dan melaksanakan setiap tugasan dalam Goroutine baharu menggunakan kata kunci go. Kemudian, kami menggunakan fungsi fmt.Scanln untuk menunggu input pengguna bagi memastikan urutan utama tidak keluar awal. doTask函数,该函数模拟执行一个任务。在main函数中,我们创建了一个任务列表,并使用go关键字在一个新的Goroutine中执行每个任务。然后,我们使用fmt.Scanln函数等待用户输入,以保证主线程不会提前退出。

当我们运行上述程序时,我们会看到所有任务并发执行,并且不会阻塞主线程。这是因为每个Goroutine都在独立的线程中运行,使得它们可以同时执行,而不会相互干扰。

除了使用独立的Goroutines执行任务外,Golang还提供了一种称为通道(Channel)的机制,用于Goroutines之间的通信。通道是一种用于在Goroutines之间传递数据的方式,它提供了同步和互斥的功能。

让我们修改上面的示例程序,使用通道来收集任务完成的信息。下面是修改后的代码示例:

package main

import (
    "fmt"
    "sync"
)

var wg sync.WaitGroup

func doTask(task string, c chan string) {
    // 模拟执行任务
    fmt.Printf("正在执行任务:%s
", task)

    // 任务完成,向通道发送消息
    c <- task
    wg.Done()
}

func main() {
    tasks := []string{"任务1", "任务2", "任务3"}
    c := make(chan string)

    for _, task := range tasks {
        wg.Add(1)
        go doTask(task, c)
    }

    // 从通道中接收任务完成的消息
    go func() {
        wg.Wait()
        close(c)
    }()

    // 处理任务完成的消息
    for task := range c {
        fmt.Printf("任务完成:%s
", task)
    }

    var input string
    fmt.Scanln(&input)
}

在上面的代码中,我们创建了一个通道c来接收任务完成的消息。每个Goroutine在完成任务后,都会向通道发送消息。我们使用sync.WaitGroup

Apabila kita menjalankan program di atas, kita akan melihat bahawa semua tugasan dilaksanakan secara serentak dan utas utama tidak akan disekat. Ini kerana setiap Goroutine berjalan dalam urutan yang berasingan, membolehkan mereka melaksanakan secara serentak tanpa mengganggu satu sama lain.

Selain menggunakan Goroutines bebas untuk melaksanakan tugas, Golang juga menyediakan mekanisme yang dipanggil Saluran untuk komunikasi antara Goroutines. Saluran ialah cara untuk menghantar data antara Goroutines, menyediakan penyegerakan dan keupayaan pengecualian bersama.

Mari ubah suai program contoh di atas untuk menggunakan saluran untuk mengumpul maklumat penyelesaian tugas. Berikut ialah contoh kod yang diubah suai:

rrreee

Dalam kod di atas, kami mencipta saluran c untuk menerima mesej penyelesaian tugas. Selepas setiap Goroutine menyelesaikan tugasnya, ia akan menghantar mesej kepada saluran. Kami menggunakan sync.WaitGroup untuk menyegerakkan semua Goroutine dan memastikan saluran ditutup selepas semua tugasan selesai.

Dalam urutan utama, kami menerima mesej penyelesaian tugas daripada saluran melalui gelung dan memprosesnya dengan sewajarnya. Apabila saluran ditutup, gelung akan keluar. 🎜🎜Melalui contoh di atas, kita dapat melihat kekuatan model pengaturcaraan serentak Golang dalam mengendalikan tugas serentak. Melalui Goroutine dan saluran, kami boleh dengan mudah melaksanakan program serentak yang cekap dan memberikan permainan penuh kepada prestasi pemproses berbilang teras. 🎜🎜Walau bagaimanapun, pengaturcaraan serentak di Golang juga mempunyai beberapa kaveat. Sebagai contoh, apabila membaca dan menulis keadaan dikongsi secara serentak, kita perlu memberi perhatian kepada isu persaingan data dan menerima pakai mekanisme penyegerakan yang sesuai untuk memastikan konsistensi data. Selain itu, menggunakan terlalu banyak Goroutine juga boleh menyebabkan kemerosotan prestasi, jadi bilangan Goroutine perlu dikawal dengan munasabah. 🎜🎜Ringkasnya, model pengaturcaraan serentak Golang ialah salah satu ciri hebatnya yang boleh membantu pembangun menulis program serentak yang cekap dan berskala. Melalui kod sampel dalam artikel ini, saya percaya pembaca boleh lebih memahami prinsip kerja Goroutines dan mula meneroka daya tarikan pengaturcaraan serentak. 🎜

Atas ialah kandungan terperinci Eksplorasi Pengaturcaraan Serentak Golang: Membongkar Misteri Goroutines. 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