cari
Rumahpembangunan bahagian belakangGolangPergi WaitGroup dan amalan terbaik untuk pengaturcaraan serentak di Golang

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")
}

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
}

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")
}

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

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
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
Membina sistem berskala dengan bahasa pengaturcaraan GoMembina sistem berskala dengan bahasa pengaturcaraan GoApr 25, 2025 am 12:19 AM

Goisidealforbuildingscalablesystemsduetoitssimplicity, ecurciency, dan barangan-inconcurrencysupport.1) go'ScleansyntaxandminimalisticdesignenhanceProductivityandreduceerrors.2)

Amalan terbaik untuk menggunakan fungsi init dengan berkesan di GOAmalan terbaik untuk menggunakan fungsi init dengan berkesan di GOApr 25, 2025 am 12:18 AM

InitFunctionsingorunautomaticallybeforemain () andareuseforforsettingupenvironmentsandinitializingvariables.usethemforsimpletasks, mengelakkansidefefects, andbecautiouswithtestingandloggingtomaintaincodeclarityAndestability.

Perintah pelaksanaan fungsi init dalam pakej GoPerintah pelaksanaan fungsi init dalam pakej GoApr 25, 2025 am 12:14 AM

GoinitializespackagesintheordertheyareImported, thenexecutesinitfunctionswithinapackageintheirdefinitionorder, danfilenamesdeterminetheorderacrossmultiplefiles

Menentukan dan menggunakan antara muka tersuai di GOMenentukan dan menggunakan antara muka tersuai di GOApr 25, 2025 am 12:09 AM

CustomInterfacesingoarecrucialForWritingFlexible, diselenggara, danTestableCode.theYenabledEveloperStofocusonbehavioroverImplementation, enhancingmodularityandrobustness.bydefiningmethodsignaturesthattypesmustimplement, interfacesallowforcorcodforcodforcodforcodforcodforcodforcodforcodeShorcodeShorcodforcodforcodeShorcodeShorcodeShorcodeShorcodeShorcodeAdeShorcodeShorcodeSoUsVorcoShorcodeS

Menggunakan antara muka untuk mengejek dan menguji di GOMenggunakan antara muka untuk mengejek dan menguji di GOApr 25, 2025 am 12:07 AM

Alasan untuk menggunakan antara muka untuk simulasi dan ujian adalah bahawa antara muka membolehkan definisi kontrak tanpa menentukan pelaksanaan, menjadikan ujian lebih terpencil dan mudah dikekalkan. 1) Pelaksanaan antara muka yang tersirat menjadikannya mudah untuk membuat objek mengejek, yang dapat menggantikan pelaksanaan sebenar dalam ujian. 2) Menggunakan antara muka dengan mudah boleh menggantikan pelaksanaan sebenar perkhidmatan dalam ujian unit, mengurangkan kerumitan ujian dan masa. 3) Fleksibiliti yang disediakan oleh antara muka membolehkan perubahan dalam tingkah laku simulasi untuk kes ujian yang berbeza. 4) Antara muka membantu reka bentuk kod yang boleh diuji dari awal, meningkatkan modulariti dan mengekalkan kod.

Menggunakan init untuk permulaan pakej di GoMenggunakan init untuk permulaan pakej di GoApr 24, 2025 pm 06:25 PM

Di GO, fungsi INIT digunakan untuk permulaan pakej. 1) Fungsi init secara automatik dipanggil apabila permulaan pakej, dan sesuai untuk memulakan pembolehubah global, menetapkan sambungan dan memuatkan fail konfigurasi. 2) Terdapat pelbagai fungsi init yang boleh dilaksanakan dalam urutan fail. 3) Apabila menggunakannya, perintah pelaksanaan, kesukaran ujian dan kesan prestasi harus dipertimbangkan. 4) Adalah disyorkan untuk mengurangkan kesan sampingan, menggunakan suntikan ketergantungan dan penangguhan permulaan untuk mengoptimumkan penggunaan fungsi INIT.

Pernyataan Pilih Go: Pelbagai operasi serentakPernyataan Pilih Go: Pelbagai operasi serentakApr 24, 2025 pm 05:21 PM

Go'sSelectStatementStreamLinesConcurrentProgrammingByMultiPlexingOperations.1) itAllowSwaitingonMultiPlechannoPerations,

Teknik Konvensyen Lanjutan di GO: Konteks dan WaitgroupsTeknik Konvensyen Lanjutan di GO: Konteks dan WaitgroupsApr 24, 2025 pm 05:09 PM

ContextandWaitGroupSarecrucialingingoformanagingGoroutinesfectively.1) ContextAllowsSignalingCancellationandDeadlinesacrosapiboundaries, memastikangoroutinescanbestplygracely.2) WaitgroupSsynchronizegoroutine, Mempersembahkan CreationAllcebeBefefeSproprophering, Preveation

See all articles

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

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Dreamweaver Mac版

Dreamweaver Mac版

Alat pembangunan web visual

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual