Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: channel, concurrency, deadlock, synchronization

Что происходит при записи в небуферизированный канал из нескольких горутин (блокировки, паника)?

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

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

При записи в небуферизированный канал горутина блокируется, пока другая горутина не прочитает данные. Если несколько горутин пишут одновременно — возникает deadlock, если нет читателей. Паники не происходит.

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

Небуферизированный канал (make(chan T)) синхронизирует горутины:

  • Запись:

    • Блокируется, пока канал не будет прочитан.

    • Если несколько горутин пишут — они ждут очередно (первая запись разблокируется при чтении).

  • Чтение:

    • Блокируется, пока не появятся данные.

Пример deadlock:

package main

func main() {
	ch := make(chan int) // Небуферизированный канал
	go func() { ch <- 1 }()
	go func() { ch <- 2 }() // Deadlock, если нет читателей
	// Нужен хотя бы один <-ch
}

Как избежать:

  1. Добавить буфер (make(chan int, 2)).

  2. Запустить читателя до записи.

Вывод:
Небуферизированные каналы полезны для синхронизации, но требуют аккуратного использования.

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    1

  • Сложность:

    7

Навыки

  • Golang

    Golang

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

#channel

#concurrency

#deadlock

#synchronization

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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