Когда buffered channel лучше не использовать или использовать осторожно?

GoMiddle+Concurrency and GoroutinesТеорияconcurrency_and_goroutinesbuffered_channelgo_backend_developer

Что хотят услышать интервьюеры:

Суть: buffered channel позволяет отправлять ограниченное число значений без немедленного receiver.

Ответ:

Пример:

jobs := make(chan Job, 100)

Практический акцент: Оцените trade-off: простота, производительность, тестируемость, связность пакетов и цена поддержки.

Типичная ошибка: делать огромный buffer вместо решения проблемы backpressure.

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

Источники

Похожие вопросы