Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: wait group, mutex, channel, atomic, concurrency

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

Этот вопрос проверяет знание примитивов для безопасной работы с конкурентными горутинами.

Короткий ответ

Синхронизация достижима через WaitGroup для ожидания завершения групп горутин, Mutex и RWMutex для защиты общих данных, Channel для обмена данными и сигнализации, а также atomic операции (sync/atomic) для безблокировочных счётчиков.

Длинный ответ

sync.WaitGroup:

var wg sync.WaitGroup
wg.Add(2)
go func() { defer wg.Done(); work() }()
go func() { defer wg.Done(); work() }()
wg.Wait()

sync.Mutex / RWMutex:

var mu sync.Mutex
mu.Lock(); shared++; mu.Unlock()

Channels:

Канал блокирует отправителя/получателя до готовности.

done := make(chan struct{})
go func() { work(); close(done) }()
<-done

sync/atomic:

Безблокировочные инкременты:

atomic.AddInt64(&counter, 1)

Вывод:

Выбирайте механизмы в зависимости от задач: блокировки для сложных структур, атомики для простых счётчиков, каналы для потоков данных.

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    2

  • Сложность:

    6

Навыки

  • Golang

    Golang

Ключевые слова

#wait group

#mutex

#channel

#atomic

#concurrency

Подпишись на Golang Developer в телеграм

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.