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

А зачем атомики в snowflake?

16 ответов

1 просмотр

Чтобы реализовать спецификацию snowflake без блокировок. Никакие функции времени не гарантируют уникальности, в случае многопоточности, и для этого есть unique_integer.

Maksim-Lapshin Автор вопроса
Petr Kozorezov
Чтобы реализовать спецификацию snowflake без блоки...

а persistent_term зачем? Тебе же нужно время и какой-то ещё инкремент в рамках текущего времени.

Maksim Lapshin
а persistent_term зачем? Тебе же нужно время и ка...

Ну инкремент считается через atomic, ссылку на который нужно где-то хранить. Вот в persistent_term эта ссылка один раз кладётся и потом используется.

Petr Kozorezov
Ну инкремент считается через atomic, ссылку на кот...

А разве согласно спецификации atomic не должен ресетиться каждый атом времени?

Petr Kozorezov
а где такое написано?

я не уверен что это в спеке, но в твиттерской реализации они ресетят каждую милисекунду

Źmićer Rubinštejn
я не уверен что это в спеке, но в твиттерской реал...

Ну вот в либе и реализуется это ресет. Только это в спеке snowflake а не атомиков.

Petr Kozorezov
Ну вот в либе и реализуется это ресет. Только это ...

я почему-то подумал что раз ты хранишь в persistant_term - то не ресетишь.

Maksim-Lapshin Автор вопроса
Źmićer Rubinštejn
А разве согласно спецификации atomic не должен рес...

а зачем? Что пойдет не так, если делать не по такому описанию?

Maksim Lapshin
а зачем? Что пойдет не так, если делать не по тако...

Для меня всегда это было загадкой. Помоему крутить до overflow экономит пару тактов

Maksim Lapshin
а зачем? Что пойдет не так, если делать не по тако...

Да, можно и не ресетить. Но по спеке ресет есть.

Maksim-Lapshin Автор вопроса
Źmićer Rubinštejn
Для меня всегда это было загадкой. Помоему крутить...

Мне кажется, что сильно больше. Ведь надо запомнить предыдущее значение времени и с ним сравнивать. Зачем это делать - не очень ясно. Откуда такое могло взяться - элементарно ясно. В libevent гораздо удобнее в начале цикла вычислить время и потом всем инкрементить.

Maksim-Lapshin Автор вопроса
Petr Kozorezov
Да, можно и не ресетить. Но по спеке ресет есть.

да вот я и хочу понять: хоть какая-то проблема от нересета есть?

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

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

а проверьте, собирается ли у кого сейчас транк лазаря через делюкс? у меня вот: fpcupdeluxe: info: Lazarus Native Installer (BuildModuleCustom: UserIDE): LazBuild: building Us...
Iluha Companets
20
добрый день. возможно ли изменить цвет окон лазаруса? Как?
Budemposmotret
35
This is a big issue. Just by being a citizen of a country, you are denied to contribute to Open Source software: https://youtu.be/L5Ec5jrpLVk?si=1iIuHnMPbCB4anV-
Sharuzzaman Ahmat Raslan
72
Господа, а кто-нибудь сталкивался с размещением на TTabControl/TTabSheet множества контролов (> 100) с последующими External: Access violation? Вот буквально на ровном месте. ...
Dmitry
29
Вот например простой пример, как получить стоимость хешрейта монеты монеро с сайта whattomine.com c использование сеарилизатора при парсинге JSON TaskProfit := TTask.Run(proc...
Delphi Coder
2
А какие существуют способы обработки ошибок выделения памяти в ядре? Т.е., допустим, есть функция, которая возвращает адрес свободной страницы в физической памяти и диапазон в...
disba1ancer
51
ну так че, сделать програмулину, в которую можно добавлять в Едиты свои строчки кода(закладки) а потом по ним прыгать. ну и сохраняться они естественно будут той програмуленно...
Kraszx
15
Does anyone have some zeroday's left?
Wito!d ♥️🩷
44
Приветствую всех!)) Подскажите, а кто мог бы написать на делфи движок (самую базу) интерпретатора очень легковесного и минималистичного языка программирования? Язык - проце...
Моринаро
8
#include <stdlib.h> #include <stdio.h> #include <math.h> #include <assert.h> #include <limits.h> long long avg3(long long a, long long b, long long c) { if (a == b && b =...
Malformed C
4
Карта сайта