170 похожих чатов

Привет, у меня есть самописный LFU кэш со сложностью

O(1). Там в основе лежит хэшмапа для хранения значений, и массив хэш сетов для хранения связанных нод и метаинформации о частоте использования объекта в кэше (индекс массива -> частота вызова сета объектов). То есть при вызове объекта из хешмапы, идёт перемешаете ноды слева направо по массиву. При eviction по размеру дропаются ноды слева. И все было ок, но сейчас мне нужно сделать кэш thread safe и при этом не потерять в эффективности. Возможно, посоветуете что есть почитать, посмотреть на эту тему. Как сделать структуру данных потоко безопасной и и.д.? Спасибо 🧐

10 ответов

5 просмотров

Почему именно самописное?

И что, при удалении элемента ближе к краю будет весь массив двигаться?

Mykyta-Berehulia Автор вопроса
Etki
И что, при удалении элемента ближе к краю будет ве...

Нет, не двигаются, просто наименее использованные, будут слева и дропнутся

Mykyta Berehulia
Нет, не двигаются, просто наименее использованные,...

Почему они должны дропаться, когда я удаляю один ключ?

Mykyta-Berehulia Автор вопроса
Etki
Почему они должны дропаться, когда я удаляю один к...

При переполнении кэша стоит eviction factor в 1%, когда в кэш вставится элемент который превышает максимальный лимит, то 1% наименее используемых объектов из него удалится

Почему бы не взять caffeine просто?

Mykyta-Berehulia Автор вопроса
Костя
Почему бы не взять caffeine просто?

Да, я смотрю его и Guava как пример, так поставлена задача 🤓

Mykyta-Berehulia Автор вопроса

Минимально инвазивно можно просто массив ридврайтлоков добавить

Похожие вопросы

Обсуждают сегодня

Какой-то там пердун в 90-х решил, что есть какая-то разная типизация. Кого вообще это волнует?
КТ315
49
void terminal_scroll() { memmove(terminal_buffer, terminal_buffer + VGA_WIDTH, buffer_size - VGA_WIDTH); memset(terminal_buffer + buffer_size - VGA_WIDTH, 0, VGA_WIDTH); ...
Егор
47
Всем привет! Подскажите, пожалуйста, в чем ошибка? Настраиваю подключение к MySQL. Либы лежат рядом с exe. Все как по "учебнику"
Евгений
16
А можете как-то проверить меня по знаниям по ассемблеру?
A A
132
Здравствуйте! У меня появилась возможность купить книгу "Изучай Haskell во имя добра!". Но я где-то слышал, что эта книга устарела. Насколько это правда??
E
22
Здравствуйте! Я вот на stepic решаю задачи на хаскеле https://stepik.org/lesson/8443/step/8?unit=1578 мой код import Data.List (isInfixOf) removing :: String -> [String] ->...
E
10
Камрады, кто тесно работал с vtv, хотел уточнить. Ширина column задаётся жёстко на этапе создания дерева или можно в рантайме ее менять программно (не мышкой)?
Ed Doc
10
да ладно ... что там неочевидного ? глянуть в исх-ки датасета и/или кверика чтобы понять в каком месте и как выполняется обращения к св-вам blablaSQL - минутное дело, даже е...
Сергей
7
Здесь для arm кто-нибудь кодит ?
Nothing
52
Всем привет, у меня есть сервер принимающий входящие HTTP подключения, как проверить, что подключение было через прокси или нет, есть какие то поля в заголовках по которым мо...
Кибер Бомж
8
Карта сайта