Как связаны WaitGroup, context cancellation и graceful shutdown?

GoMiddleConcurrency and GoroutinesТеорияconcurrency_and_goroutineswaitgroupgo_backend_developer

Что хотят услышать интервьюеры:

Суть:

Ответ:

sync.WaitGroup

ждет завершения группы goroutine.

Пример:

wg.Add(1);
go func(){
  defer wg.Done()
}
();
wg.Wait()

Практический акцент: Связывайте это с context propagation: операция должна уметь завершаться, когда запрос отменен или сервис останавливается.

Типичная ошибка: вызывать Add внутри goroutine и ловить race с Wait.

Как отвечать на собеседовании: Ответ должен показывать, что вы управляете жизненным циклом goroutine, синхронизацией, отменой и нагрузкой, а не просто знаете слово channel.

Источники

Похожие вопросы