Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: golang, channel, buffer, concurrency

Чем отличаются буферизованные и небуферизованные каналы в Go?

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

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

Небуферизованный канал блокирует отправителя до получения значения, а получателя — до отправки. Буферизованный позволяет отправлять несколько значений, пока буфер не заполнится.

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

Каналы — основной способ синхронизации горутин в Go.

  • Небуферизованный канал (make(chan int)) передаёт значение только при одновременном send и receive. Это обеспечивает строгую синхронизацию.

  • Буферизованный канал (make(chan int, N)) хранит до N значений. Отправитель блокируется только если буфер заполнен, а получатель — если буфер пуст.

ch := make(chan int, 2) // буфер на 2
ch <- 1
ch <- 2
// третья отправка заблокируется, пока не будет чтения

Вывод:

  • небуферизованные каналы хороши для строгой синхронизации;

  • буферизованные — для балансировки нагрузки и очередей.

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    5

  • Сложность:

    3

Навыки

  • Golang

    Golang

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

#golang

#channel

#buffer

#concurrency

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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