Rumah >pembangunan bahagian belakang >Golang >Kuasai pengaturcaraan berbilang benang dan kawalan serentak dalam bahasa Go

Kuasai pengaturcaraan berbilang benang dan kawalan serentak dalam bahasa Go

PHPz
PHPzasal
2023-11-30 10:29:22537semak imbas

Kuasai pengaturcaraan berbilang benang dan kawalan serentak dalam bahasa Go

Kuasai pengaturcaraan berbilang benang dan kawalan konkurensi dalam bahasa Go

Abstrak: Artikel ini memperkenalkan konsep asas dan penggunaan pengaturcaraan berbilang benang dan kawalan konkurensi dalam bahasa Go. Melalui pengenalan dan analisis contoh penggunaan goroutine dan saluran dalam bahasa Go, ia boleh membantu pembaca menguasai kemahiran pengaturcaraan berbilang benang dan kawalan konkurensi dalam bahasa Go untuk meningkatkan prestasi dan kecekapan program.

  1. Pengenalan

Dengan pembangunan perkakasan komputer, pemproses berbilang teras telah menjadi arus perdana komputer moden. Untuk mengeksploitasi sepenuhnya potensi pemproses berbilang teras, pembangun perlu melaksanakan kawalan konkurensi melalui pengaturcaraan berbilang benang. Walau bagaimanapun, kaedah pengaturcaraan berbilang benang tradisional sering menyebabkan beberapa masalah, seperti kebuntuan, keadaan perlumbaan, dsb. Untuk menyelesaikan masalah ini, bahasa Go menyediakan pengaturcaraan berbilang benang dan kaedah kawalan konkurensi yang mudah dan berkuasa.

  1. Konsep asas Goroutine dan saluran

Groutine dalam bahasa Go ialah benang ringan yang boleh melaksanakan tugas secara serentak dalam program. Berbanding dengan benang tradisional, goroutine mempunyai permulaan yang sangat sedikit dan overhed pemusnahan dan boleh mencapai kesesuaian berskala besar dengan cekap. Dalam bahasa Go, anda boleh memulakan goroutine melalui kata kunci go, contohnya:

go func() {
    // 任务代码
}()

saluran ialah mekanisme komunikasi yang digunakan untuk menghantar data antara goroutine. Saluran boleh dianggap sebagai paip yang melaluinya goroutine boleh menghantar dan menerima data. Dalam bahasa Go, anda boleh menggunakan kata kunci make untuk mencipta saluran, contohnya:

ch := make(chan int)
  1. Contoh penggunaan Goroutine

Berikut ialah contoh mudah untuk menggambarkan cara menggunakan goroutine untuk pengaturcaraan serentak. Katakan terdapat fungsi yang mengira nombor perdana Pengiraan selari boleh dilakukan dengan cara berikut:

func isPrime(n int) bool {
    if n < 2 {
        return false
    }
    for i := 2; i * i <= n; i++ {
        if n % i == 0 {
            return false
        }
    }
    return true
}

func main() {
    num := 100
    ch := make(chan int)

    for i := 2; i <= num; i++ {
        go func(n int) {
            if isPrime(n) {
                ch <- n
            }
        }(i)
    }

    for i := 2; i <= num; i++ {
        fmt.Println(<-ch)
    }
}

Dalam kod di atas, mula-mula buat saluran ch untuk menerima nombor perdana yang dikira. Kemudian gunakan gelung for untuk memulakan berbilang goroutin untuk mengira nombor perdana pada masa yang sama Selepas setiap goroutine melengkapkan pengiraan, keputusan dihantar ke saluran ch. Akhir sekali, baca dan cetak nombor perdana dari saluran ch melalui gelung untuk. Dengan menggunakan goroutine, berbilang nombor perdana boleh dikira dengan cekap serentak dan kecekapan pelaksanaan program boleh dipertingkatkan.

  1. Concurrency control

Selain menggunakan goroutine untuk melaksanakan pengaturcaraan serentak, bahasa Go juga menyediakan beberapa mekanisme untuk kawalan serentak. Sebagai contoh, anda boleh menggunakan jenis Mutex dalam kata kunci penyegerakan untuk melaksanakan kunci mutex untuk melindungi akses kepada sumber yang dikongsi. Contohnya adalah seperti berikut:

import "sync"

var count int
var mutex sync.Mutex

func increment() {
    mutex.Lock()
    count++
    mutex.Unlock()
}

func main() {
    var wg sync.WaitGroup
    num := 100

    wg.Add(num)
    for i := 0; i < num; i++ {
        go func() {
            defer wg.Done()
            increment()
        }()
    }

    wg.Wait()
    fmt.Println(count)
}

Dalam kod di atas, kiraan pembolehubah yang dikongsi dan mutex kunci mutex ditakrifkan dahulu. Kemudian gunakan berbilang goroutin untuk memanggil fungsi kenaikan secara serentak, yang menggunakan mutex untuk melindungi akses kiraan. Akhir sekali, WaitGroup digunakan untuk menunggu semua goroutine dilaksanakan dan mencetak hasil kiraan. Dengan menggunakan kunci mutex, anda boleh memastikan bahawa akses kepada sumber yang dikongsi adalah selamat dan mengelakkan keadaan perlumbaan.

  1. Ringkasan

Artikel ini memperkenalkan konsep asas dan penggunaan pengaturcaraan berbilang benang dan kawalan konkurensi dalam bahasa Go. Melalui pengenalan dan analisis contoh penggunaan goroutine dan saluran dalam bahasa Go, ia boleh membantu pembaca menguasai kemahiran pengaturcaraan berbilang benang dan kawalan konkurensi dalam bahasa Go untuk meningkatkan prestasi dan kecekapan program. Pada masa yang sama, ia juga memperkenalkan penggunaan mekanisme kawalan konkurensi seperti kunci mutex untuk memastikan akses selamat kepada sumber yang dikongsi. Menguasai pengaturcaraan berbilang benang dan kawalan konkurensi bagi bahasa Go akan sangat membantu dalam membangunkan aplikasi berprestasi tinggi dan berkonkurensi tinggi.

Atas ialah kandungan terperinci Kuasai pengaturcaraan berbilang benang dan kawalan serentak dalam bahasa Go. 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