Как связаны semaphore через channel, context cancellation и graceful shutdown?
Что хотят услышать интервьюеры:
Суть: buffered channel можно использовать как semaphore для лимита параллелизма.
Ответ:
Пример:
sem := make(chan struct{
}
, 10);
sem <- struct{
}
{
}
;
defer func(){
<-sem
}
() Практический акцент: Связывайте это с context propagation: операция должна уметь завершаться, когда запрос отменен или сервис останавливается.
Типичная ошибка: забыть release и заблокировать всю систему.
Как отвечать на собеседовании: Ответ должен показывать, что вы управляете жизненным циклом goroutine, синхронизацией, отменой и нагрузкой, а не просто знаете слово channel.