Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: golang, time, timer, memory

Почему time.After может приводить к утечкам памяти?

Вопрос проверяет знание таймеров, каналов и работы runtime Go.

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

time.After создаёт таймер, который нельзя отменить. Если результат не будет прочитан, таймер останется в памяти до срабатывания.

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

time.After(d) под капотом создаёт time.Timer и возвращает канал. Если таймер больше не нужен, его невозможно остановить.

Проблема возникает в select:

select {
case <-time.After(time.Minute):
case <-ctx.Done():
}

Если ctx.Done() срабатывает первым:

  • таймер продолжает жить;

  • канал никто не читает;

  • при большом количестве вызовов → рост памяти.

Правильный подход — time.NewTimer:

timer := time.NewTimer(time.Minute)
defer timer.Stop()

select {
case <-timer.C:
case <-ctx.Done():
}
  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    4

  • Сложность:

    7

Навыки

  • Golang

    Golang

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

#golang

#time

#timer

#memory

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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