Как select помогает избежать блокировок, deadlock или утечки goroutine?

GoMiddleConcurrency and GoroutinesТеорияconcurrency_and_goroutinesselectgo_backend_developer

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

Суть:

Ответ:

select

ждет одну из нескольких операций channel и часто используется с timeout/cancel.

Пример:

select { case v := <-ch: return v; case <-ctx.Done(): return ctx.Err() }

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

Типичная ошибка: писать select без обработки cancel и блокировать shutdown.

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

Источники

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