Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Python: gc, refcount, cyclic, generation, memory

Как работает сборщик мусора в Python? Как он определяет, что объект можно удалить?

Проверяет знание механизмов управления памятью и GC в CPython.

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

CPython использует подсчёт ссылок и циклический сборщик. Когда счётчик ссылок объекта падает до нуля, память освобождается. Cyclic GC по таймеру ищет группы объектов, недоступных из корневых ссылок, несмотря на циклические ссылки, и удаляет их.

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

Подсчёт ссылок:

  • Каждый объект хранит счётчик ссылок; при присваивании/increment он растёт, при удалении — уменьшается.

  • При нулевом счётчике объект сразу удаляется.

Cylic GC (модуль gc):

  • Три поколения (0, 1, 2) по частоте проверки.

  • При достижении порога поколения запускается сборка: ищутся unreachable‑объекты, участвующие в циклах.

Определение удаления:

  • Объект считаётся «мусором», если до него нет цепочки ссылок из корней (стек, глобальные имена).

  • Для циклов — GC детектирует группу объектов, ссылающихся друг на друга, но недостижимых извне.

Вывод:

  • Подсчёт ссылок — быстрый, но не решает циклы.

  • Cyclic GC дополняет его, очищая циклические зависимости.

  • Аватар

    Python Guru

    Sergey Filichkin

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

Уровень

  • Рейтинг:

    3

  • Сложность:

    6

Навыки

  • Python

    Python

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

#gc

#refcount

#cyclic

#generation

#memory

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

  • Аватар

    Python Guru

    Sergey Filichkin

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