Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: striped lock, sharding

Объясни, что такое striped locking и когда он эффективнее обычного mutex.

Проверяет знание методов снижения contention в многопоточных структурах.

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

Striped locking — это подход, когда один общий ресурс разделяется на множество независимых сегментов, каждый со своим mutex. Это снижает блокировки, позволяя параллелить операции.

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

Striping состоит из:

  • большого массива lock’ов (обычно степень двойки),

  • хеш-функции, выбирающей lock,

  • изоляции операций между сегментами.

Пример (Golang):

type StripedMap struct {
		locks [64]sync.Mutex
		data  [64]map[string]string
}

func (m *StripedMap) Set(k, v string) {
		idx := fnvHash(k) % 64
		m.locks[idx].Lock()
		defer m.locks[idx].Unlock()
		m.data[idx][k] = v
}

Преимущества:

  • уменьшение contention;

  • масштабирование на много потоков;

  • эффективная альтернатива sync.Map.

Недостатки:

  • сложность реализации;

  • невозможность атомарных операций над всей структурой.

Вывод:

Striped locking хорош для highly concurrent структур, где доступ делится на независимые сегменты.

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    3

  • Сложность:

    9

Навыки

  • Golang

    Golang

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

#striped lock

#sharding

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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