Sobes.tech
Назад к вопросам
Junior — Middle
76

Как реализовать синхронное ожидание завершения нескольких параллельных задач в программе на языке Go?

Компании, где спрашивали
YadroYadro
Киберпротект

Ответ от нейросети

sobes.tech AI

В Go для синхронного ожидания завершения нескольких параллельных задач обычно используют sync.WaitGroup. Он позволяет запустить несколько горутин и дождаться их завершения.

Пример:

package main

import (
    "fmt"
    "sync"
)

func worker(id int, wg *sync.WaitGroup) {
    defer wg.Done() // Сообщаем WaitGroup, что задача завершена
    fmt.Printf("Worker %d started\n", id)
    // имитация работы
    // time.Sleep(time.Second)
    fmt.Printf("Worker %d finished\n", id)
}

func main() {
    var wg sync.WaitGroup
    numWorkers := 3

    wg.Add(numWorkers) // Устанавливаем количество задач

    for i := 1; i <= numWorkers; i++ {
        go worker(i, &wg)
    }

    wg.Wait() // Ожидаем завершения всех горутин
    fmt.Println("All workers finished")
}

Таким образом, WaitGroup позволяет эффективно синхронизировать выполнение параллельных задач.