Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: scheduler, ready, queue

Как goroutine возвращается к выполнению после блокировки?

Вопрос проверяет понимание механизма пробуждения goroutine и очередей планировщика.

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

Когда событие, на которое ожидала goroutine, происходит, runtime переводит ее в очередь готовых к выполнению. Планировщик затем назначает ее на доступный поток. Это происходит автоматически и прозрачно для разработчика. Механизм используется для каналов, mutex и I/O.

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

После блокировки goroutine находится в состоянии ожидания.

Механизм возврата

Когда событие происходит:

  1. Канал получает данные.

  2. Mutex освобождается.

  3. Завершается I/O.

Runtime:

  1. Помещает goroutine в ready queue.

  2. Планировщик выбирает ее для выполнения.

Роль планировщика

Планировщик:

  1. Распределяет goroutine по потокам.

  2. Балансирует нагрузку.

  3. Минимизирует переключения контекста.

Важный момент

Разработчик:

  1. Не управляет пробуждением вручную.

  2. Работает через каналы и синхронизацию.

Runtime берет управление на себя.

Вывод

Goroutine возвращается к выполнению, когда runtime фиксирует событие, переводит ее в очередь готовых и планировщик назначает поток.

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    4

  • Сложность:

    6

Навыки

  • Golang

    Golang

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

#scheduler

#ready

#queue

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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