Rumah pembangunan bahagian belakang Golang Pergi WaitGroup dan amalan terbaik untuk pengaturcaraan serentak di Golang

Pergi WaitGroup dan amalan terbaik untuk pengaturcaraan serentak di Golang

Sep 28, 2023 pm 02:33 PM
golang Pengaturcaraan serentak waitgroup

Go WaitGroup和Golang并发编程的最佳实践

Go WaitGroup dan amalan terbaik untuk pengaturcaraan serentak di Golang

Abstrak:
Dalam pengaturcaraan serentak, bahasa WaitGroup of Go ialah alat penting. Artikel ini akan memperkenalkan apa itu WaitGroup dan cara menggunakannya untuk mengurus tugasan serentak Ia juga akan menyediakan beberapa contoh kod praktikal untuk membantu pembaca memahami dan menggunakan WaitGroup dengan lebih baik.

Pengenalan:
Dengan pembangunan perkakasan komputer, pemproses berbilang teras telah menjadi konfigurasi standard komputer moden. Untuk memanfaatkan sepenuhnya kelebihan prestasi pemproses berbilang teras, kita perlu menggunakan pengaturcaraan serentak untuk mencapai pelaksanaan tugas secara serentak. Bahasa Go ialah bahasa pengaturcaraan serentak yang berkuasa yang menyediakan satu siri alat dan mekanisme pengaturcaraan serentak.

Dalam bahasa Go, WaitGroup ialah alat penting untuk menyelaraskan tugas serentak. Ia membolehkan kami menunggu satu set tugasan serentak selesai sebelum meneruskan ke langkah seterusnya, dengan itu mengurus dan mengawal tugas serentak dengan berkesan. Artikel ini akan memperkenalkan prinsip dan penggunaan WaitGroup secara terperinci, dan menyediakan beberapa senario penggunaan biasa dan contoh kod dalam projek sebenar.

1. Prinsip dan penggunaan asas WaitGroup
1.1 Prinsip asas WaitGroup
Dalam pengaturcaraan serentak, WaitGroup berfungsi seperti kaunter. Kita boleh menambah bilangan tugasan yang perlu ditunggu kepada WaitGroup melalui kaedah Tambah, dan kemudian menunjukkan bahawa tugasan telah diselesaikan melalui kaedah Selesai. Dengan memanggil kaedah Tunggu, kami boleh menyekat utas utama sehingga semua tugas selesai. Apabila kaunter dalam WaitGroup mencapai 0, utas utama meneruskan pelaksanaan.

1.2 Penggunaan asas WaitGroup
Sebelum menggunakan WaitGroup, kita perlu mengimport pakej penyegerakan terlebih dahulu, kerana WaitGroup adalah sebahagian daripada pakej. Seterusnya, kita perlu mencipta objek WaitGroup dan kemudian menambah bilangan tugas untuk menunggu dengan memanggil kaedah Tambah. Selepas itu, sebelum setiap tugasan bermula, kita perlu memanggil kaedah Selesai di dalam tugasan untuk menunjukkan penyelesaian tugas. Akhir sekali, kita boleh memanggil kaedah Tunggu untuk menyekat utas utama sehingga semua tugas selesai.

Berikut ialah contoh penggunaan asas:

package main

import (
    "fmt"
    "sync"
)

func main() {
    var wg sync.WaitGroup

    wg.Add(2)

    go func() {
        defer wg.Done()
        fmt.Println("Task 1 executed")
    }()

    go func() {
        defer wg.Done()
        fmt.Println("Task 2 executed")
    }()

    wg.Wait()

    fmt.Println("All tasks completed")
}
Salin selepas log masuk

Dalam kod di atas, kami mencipta objek WaitGroup dan menetapkan bilangan tugas kepada 2 menggunakan kaedah Tambah. Kemudian, kami menggunakan dua fungsi tanpa nama untuk melaksanakan tugasan 1 dan tugasan 2 masing-masing. Pada akhir setiap tugasan, kami menggunakan kata kunci tangguh untuk memanggil kaedah Selesai. Akhir sekali, kami memanggil kaedah Tunggu untuk menyekat utas utama sehingga semua tugas selesai. Apabila semua tugas selesai, program akan mencetak "Semua tugas selesai".

2. Penggunaan lanjutan Go WaitGroup
2.1 Ralat pengendalian dalam tugasan serentak
Dalam senario aplikasi sebenar, kami sering menghadapi ralat dalam mengendalikan tugasan serentak. Untuk dapat menangani ralat ini dengan cekap dan mengelakkan ranap program, kita perlu menghantar ralat ke utas utama. Dalam bahasa Go, kita boleh menggunakan saluran untuk menghantar ralat.

Berikut ialah contoh kod untuk mengendalikan ralat dalam tugasan serentak:

package main

import (
    "fmt"
    "sync"
)

func main() {
    var wg sync.WaitGroup
    errChan := make(chan error)

    wg.Add(2)

    go func() {
        defer wg.Done()
        err := task1()
        if err != nil {
            errChan <- err
        }
    }()

    go func() {
        defer wg.Done()
        err := task2()
        if err != nil {
            errChan <- err
        }
    }()

    go func() {
        wg.Wait()
        close(errChan)
    }()

    for err := range errChan {
        fmt.Println("Error:", err)
    }

    fmt.Println("All tasks completed")
}

func task1() error {
    // 执行任务1
    return nil
}

func task2() error {
    // 执行任务2
    return nil
}
Salin selepas log masuk

Dalam kod di atas, kami mencipta saluran (errChan) untuk menghantar ralat. Pada akhir setiap tugasan, jika ralat berlaku, kami menghantar ralat itu kepada errChan. Seterusnya, kami menggunakan gelung for untuk menerima ralat dalam errChan dan mengendalikannya. Apabila semua tugas selesai, program akan mencetak "Semua tugas selesai". Sila ambil perhatian bahawa tugas1 dan tugas2 adalah contoh fungsi simulasi dan kami boleh menggantikannya mengikut keperluan sebenar.

2.2 Kawal bilangan tugas serentak
Kadangkala, kita mungkin perlu mengehadkan bilangan tugas serentak untuk mengelakkan penggunaan sumber yang berlebihan. Dalam bahasa Go, kita boleh menggunakan WaitGroup dan Semaphore untuk mengawal bilangan tugasan serentak.

Berikut ialah contoh kod untuk mengawal bilangan tugasan serentak:

package main

import (
    "fmt"
    "sync"
)

func main() {
    var wg sync.WaitGroup
    sem := make(chan int, 3)  // 限制并发任务数量为3

    for i := 0; i < 5; i++ {
        wg.Add(1)
        sem <- 1 // 请求一个信号量,表示可以开始一个新的任务
        go func(taskIndex int) {
            defer wg.Done()
            fmt.Println("Task", taskIndex, "executed")
            <-sem // 释放一个信号量,表示任务执行完成
        }(i)
    }

    wg.Wait()
    close(sem)

    fmt.Println("All tasks completed")
}
Salin selepas log masuk

Dalam kod di atas, kami mencipta saluran buffered (sem) untuk menyimpan semaphore. Dengan menetapkan kapasiti saluran kepada 3, kita boleh mengehadkan bilangan tugasan serentak kepada 3. Pada permulaan setiap tugasan, kami mula-mula meminta semaphore untuk menunjukkan bahawa tugasan baharu boleh dimulakan. Kemudian, pada akhir setiap tugas, kami mengeluarkan semaphore melalui <-sem.

3. Ringkasan
Melalui pengenalan artikel ini, kami telah mempelajari tentang prinsip asas dan penggunaan Go WaitGroup, serta beberapa penggunaan lanjutan. Dengan menggunakan WaitGroup dengan betul, kami boleh mengurus dan mengawal tugas serentak dengan lebih baik, dengan itu meningkatkan prestasi dan kebolehpercayaan program.

Perlu diingatkan bahawa dalam pembangunan sebenar, kita juga perlu memberi perhatian kepada pengendalian kesilapan dalam tugas serentak dan mengawal bilangan tugas serentak secara munasabah. Ini adalah teknik lanjutan untuk menggunakan WaitGroup yang boleh membantu kami membina aplikasi serentak yang lebih mantap dan cekap.

Saya harap artikel ini dapat membantu pembaca lebih memahami dan menggunakan Go WaitGroup, dan memanfaatkannya dalam projek sebenar. Saya berharap anda semua yang terbaik untuk pergi lebih jauh dan lebih jauh ke arah pengaturcaraan serentak!

Atas ialah kandungan terperinci Pergi WaitGroup dan amalan terbaik untuk pengaturcaraan serentak di Golang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Akan R.E.P.O. Ada Crossplay?
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk membaca dan menulis fail dengan selamat menggunakan Golang? Bagaimana untuk membaca dan menulis fail dengan selamat menggunakan Golang? Jun 06, 2024 pm 05:14 PM

Membaca dan menulis fail dengan selamat dalam Go adalah penting. Garis panduan termasuk: Menyemak kebenaran fail Menutup fail menggunakan tangguh Mengesahkan laluan fail Menggunakan tamat masa konteks Mengikuti garis panduan ini memastikan keselamatan data anda dan keteguhan aplikasi anda.

Bagaimana untuk mengkonfigurasi kolam sambungan untuk sambungan pangkalan data Golang? Bagaimana untuk mengkonfigurasi kolam sambungan untuk sambungan pangkalan data Golang? Jun 06, 2024 am 11:21 AM

Bagaimana untuk mengkonfigurasi pengumpulan sambungan untuk sambungan pangkalan data Go? Gunakan jenis DB dalam pakej pangkalan data/sql untuk membuat sambungan pangkalan data untuk mengawal bilangan maksimum sambungan serentak;

Bagaimana untuk menyimpan data JSON ke pangkalan data di Golang? Bagaimana untuk menyimpan data JSON ke pangkalan data di Golang? Jun 06, 2024 am 11:24 AM

Data JSON boleh disimpan ke dalam pangkalan data MySQL dengan menggunakan perpustakaan gjson atau fungsi json.Unmarshal. Pustaka gjson menyediakan kaedah kemudahan untuk menghuraikan medan JSON dan fungsi json.Unmarshal memerlukan penuding jenis sasaran kepada data JSON unmarshal. Kedua-dua kaedah memerlukan penyediaan pernyataan SQL dan melaksanakan operasi sisipan untuk mengekalkan data ke dalam pangkalan data.

Rangka Kerja Golang lwn Rangka Kerja Go: Perbandingan Seni Bina Dalaman dan Ciri Luaran Rangka Kerja Golang lwn Rangka Kerja Go: Perbandingan Seni Bina Dalaman dan Ciri Luaran Jun 06, 2024 pm 12:37 PM

Perbezaan antara rangka kerja GoLang dan rangka kerja Go ditunjukkan dalam seni bina dalaman dan ciri luaran. Rangka kerja GoLang adalah berdasarkan perpustakaan standard Go dan meluaskan fungsinya, manakala rangka kerja Go terdiri daripada perpustakaan bebas untuk mencapai tujuan tertentu. Rangka kerja GoLang lebih fleksibel dan rangka kerja Go lebih mudah digunakan. Rangka kerja GoLang mempunyai sedikit kelebihan dalam prestasi dan rangka kerja Go lebih berskala. Kes: gin-gonic (rangka Go) digunakan untuk membina REST API, manakala Echo (rangka kerja GoLang) digunakan untuk membina aplikasi web.

Apakah amalan terbaik untuk pengendalian ralat dalam rangka kerja Golang? Apakah amalan terbaik untuk pengendalian ralat dalam rangka kerja Golang? Jun 05, 2024 pm 10:39 PM

Amalan terbaik: Cipta ralat tersuai menggunakan jenis ralat yang ditakrifkan dengan baik (pakej ralat) Sediakan lebih banyak butiran Log ralat dengan sewajarnya Sebarkan ralat dengan betul dan elakkan menyembunyikan atau menyekat ralat Balut seperti yang diperlukan untuk menambah konteks

Bagaimana untuk mencari subrentetan pertama dipadankan dengan ungkapan biasa Golang? Bagaimana untuk mencari subrentetan pertama dipadankan dengan ungkapan biasa Golang? Jun 06, 2024 am 10:51 AM

Fungsi FindStringSubmatch mencari subrentetan pertama dipadankan dengan ungkapan biasa: fungsi mengembalikan hirisan yang mengandungi subrentetan yang sepadan, dengan elemen pertama ialah keseluruhan rentetan dipadankan dan elemen berikutnya ialah subrentetan individu. Contoh kod: regexp.FindStringSubmatch(teks,corak) mengembalikan sekeping subrentetan yang sepadan. Kes praktikal: Ia boleh digunakan untuk memadankan nama domain dalam alamat e-mel, contohnya: e-mel:="user@example.com", pattern:=@([^\s]+)$ untuk mendapatkan padanan nama domain [1].

Bagaimana untuk menyelesaikan masalah keselamatan biasa dalam rangka kerja golang? Bagaimana untuk menyelesaikan masalah keselamatan biasa dalam rangka kerja golang? Jun 05, 2024 pm 10:38 PM

Cara menangani isu keselamatan biasa dalam rangka kerja Go Dengan penggunaan meluas rangka kerja Go dalam pembangunan web, memastikan keselamatannya adalah penting. Berikut ialah panduan praktikal untuk menyelesaikan masalah keselamatan biasa, dengan kod sampel: 1. SQL Injection Gunakan pernyataan yang disediakan atau pertanyaan berparameter untuk mengelakkan serangan suntikan SQL. Contohnya: constquery="SELECT*FROMusersWHEREusername=?"stmt,err:=db.Prepare(query)iferr!=nil{//Handleerror}err=stmt.QueryR

Berubah dari front-end ke pembangunan back-end, adakah lebih menjanjikan untuk belajar Java atau Golang? Berubah dari front-end ke pembangunan back-end, adakah lebih menjanjikan untuk belajar Java atau Golang? Apr 02, 2025 am 09:12 AM

Laluan Pembelajaran Backend: Perjalanan Eksplorasi dari Front-End ke Back-End sebagai pemula back-end yang berubah dari pembangunan front-end, anda sudah mempunyai asas Nodejs, ...

See all articles