Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: goroutines, concurrency, buffered, channel

Как каналы устроены в Go?

Этот вопрос проверяет знание структуры и работы каналов в Go. Каналы — это ключевой инструмент для реализации конкурентности.

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

Каналы в Go используются для передачи данных между горутинами. Они могут быть буферизированными и неблокирующими либо небуферизированными и блокирующими. Работа каналов основана на принципах синхронизации и безопасности при параллельном выполнении.

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

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

  • Небуферизированные каналы — передача данных происходит только при наличии получателя. Они используются для синхронизации горутин.

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

Создание канала:

ch := make(chan int) // Небуферизированный канал
chBuf := make(chan int, 5) // Буферизированный канал ёмкостью 5

Передача и получение данных:

go func() {
    	ch <- 42 // Отправляем значение в канал
}()
value := <-ch // Получаем значение из канала
fmt.Println(value)

Закрытие канала: Каналы можно закрывать с помощью функции close. После закрытия нельзя отправлять данные, но получать их можно, пока канал не станет пустым.

Пример:

package main
import "fmt"

func main() {
    	ch := make(chan int, 2)
    	ch <- 1
    	ch <- 2
    	close(ch)

    	for val := range ch {
        	fmt.Println(val)
    	}
}

В каких случаях использовать:

  • Для синхронизации между горутинами.

  • Для передачи данных между задачами без использования глобальных переменных.

  • Для реализации паттернов "Producer-Consumer" или "Fan-Out/Fan-In".

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    5

  • Сложность:

    7

Навыки

  • Golang

    Golang

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

#goroutines

#concurrency

#buffered

#channel

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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