Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: slice, append, capacity, allocation

Как работает увеличение capacity слайса при добавлении элементов (правило удвоения до 1024 элементов)?

Этот вопрос проверяет понимание внутренней реализации слайсов в Go и поведения при увеличении их емкости.

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

Когда в слайс добавляется элемент и текущей capacity недостаточно, Go выделяет новый массив с большей емкостью. До capacity 1024 размер удваивается, после этого рост становится линейным (примерно +25%). Это позволяет эффективно управлять памятью и снижать количество аллокаций.

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

Механизм увеличения capacity слайса (slice) в Go основан на адаптивной стратегии роста, чтобы сбалансировать производительность и потребление памяти.

Как это работает:

  1. Добавление элемента (append):

    • Если в слайсе хватает capacity, элемент просто добавляется.

    • Если capacity не хватает — создаётся новый массив, и все данные копируются.

  2. Правило увеличения:

    • Пока capacity < 1024, размер нового массива удваивается (cap * 2).

    • Когда capacity >= 1024, прирост составляет примерно 25% (т.е. cap = cap + cap/4).

Пример:

s := make([]int, 0, 1)
for i := 0; i < 10; i++ {
	fmt.Printf("len=%d cap=%d\n", len(s), cap(s))
	s = append(s, i)
}

Результат:

len=1 cap=1
len=2 cap=2
len=3 cap=4
len=4 cap=4
len=5 cap=8
...

Почему это важно:

  • Меньше аллокаций: увеличение capacity снижает частоту выделения памяти.

  • Контроль над производительностью: можно предварительно задать нужный capacity, если известно количество элементов.

Вывод:
Стоит учитывать алгоритм роста capacity при работе с большими массивами. Для оптимальной производительности лучше заранее указывать capacity, если известно количество элементов.

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    1

  • Сложность:

    7

Навыки

  • Golang

    Golang

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

#slice

#append

#capacity

#allocation

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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