атомарную переменную, другие читают, причем намного чаще, чем писатель пишет. Как правильно организовать чтение, чтобы это работало максимально быстро, если читающим не особо важно, прочитают они новые данные или старые? Тут надо как-то правильно воспользоваться memory ordering?
Если x86 то делай наивно
Это как?
Просто load memory_order::relaxed
В итоге, если ваши так сделаю, то норм?
И load и stor?
Уж не текущее ли время он туда пишет? :)
А зачем? clock_gettime тоже просто переменную читает
Зачем, не знаю, не мой код. А что, это лучше будет?
Конечно, просто time(nullptr)
Согласен. Но для чего-то сделали вот так... Может чтобы лишний раз не дергать систему с вопросом "который час"?
стоит пользоваться гарантиями языка, а не платформы
к тому же это было бы UB =)
Ну вот в каких то версиях chrono помнится не использовался vdso. Но и в этом случае либо проверять либо свои clock написать, которые будут напрямую clock_gettime звать.
Он так или иначе пользуется гарантиями языка, а то как он ими пользуется, обозначает платформа, от этого не уйти
фраза на x86 это атомарно - бесполезна в контексте языка
не вижу дальше ничего полезного
Во, но это применительно к chrono: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=59177 В общем свои clock надёжнее.
Свои, это как я описал в первом сообщении?
нет, просто дергаешь clock_gettime из глибц
А это не дорого, когда куча потоков будут дергать clock_gettime?
нет, если ядро современное
Если хочется chrono, можно просто аналог system_clock но с блэкджеком. Хотя там же с tzdb наверное будет не срастить и с std format. И это печаль кстати, теоретически и то и другое можно было бы сделать не для конкретных clock. Для обоих случаев мне кажется было бы достаточно просто потребовать от Clock конверсии в time_t. Ну тогда замену system_clock::now можно по простому. Но свои clock иногда тоже хорошо, мне вот нравится 64 бита в микросекундах AD, запас всё равно большой, но можно примерно 0 считать null, 1 jan 1 AD. Тогда всё iso-форматируемое в тип влезает и default-initialized 0 как null тоже ok, не какой нить там 1970-01-01
Обсуждают сегодня