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

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

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

Суть: buffered channel можно использовать как semaphore для лимита параллелизма.

Ответ:

Пример:

sem := make(chan struct{
}
, 10);
sem <- struct{
}
{
}
;
defer func(){
  <-sem
}
()

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

Типичная ошибка: забыть release и заблокировать всю систему.

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

Источники

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