Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: buffered channel, unbuffered channel, synchronization, performance

В чём разница между буферизированным и небуферизированным каналом? Какой из них быстрее передаст значение?

Проверяет знание блокировок и производительности разных типов каналов.

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

Небуферизированный канал (cap=0) синхронизирует горутины: отправитель блокируется до приёма, буферизированный (cap>0) позволяет передавать без блокировки до заполнения. Для одиночной передачи без контеншенов небуферизированный быстрее, так как исключает работу с буфером, но при высокой конкуренции буферизированный снижает блокировки и даёт лучшую производительность.

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

Небуферизированный (make(chan T)):

  • send ждёт recv.

  • Минимальный оверхед, но жёсткая синхронизация.

Буферизированный (make(chan T, n)):

  • send не блокирует до заполнения буфера.

  • Подходит для разгрузки шины между producer/consumer.

Производительность:

  • Для точечного обмена без конкуренции небуферизированный быстрее.

  • При множестве производителей и потребителей буферизированный снижает взаимные блокировки.

Пример выбора:

  • cap=1 для ускорения передачи без полного буфера.

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    2

  • Сложность:

    6

Навыки

  • Golang

    Golang

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

#buffered channel

#unbuffered channel

#synchronization

#performance

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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