максимально экономно по памяти на диске (то есть в бинарном виде). Нужно сделать это переносимо. bitfield не подходят, т.к. то, как они хранятся в памяти и сколько места занимают, — implementation defined.
Если хранить все нужные мне числа в std::uint8_t и использовать битовые операции для чтения и записи чисел нужного мне размера, то вроде получится переносимо (остаётся только bigEndian, littleEndian). Правильны ли мои рассуждения? Может быть есть какой-то другой способ?
Меня смущает только "на диске". Вы учитываете гранулярность операций на самом устройстве? Там проблемы байтиков могут резко стать менее актуальными))
Если быть точнее, то данные будут хранится в postgresql в колонке с типом bytea. И я не буду писать в базу на каждый чих. (если я правильно понял, что гранулярность — это блокировка)
BE LE это же про порядок байтов. Порядок битов вроде везде одинаковый был кроме совсем экзотики
всем спасибо за помощь
https://en.cppreference.com/w/cpp/utility/bitset Ну есть еще такая тема, но неуверен насколько поможет
тоже implementation defined
Что именно?
https://stackoverflow.com/questions/12459563/what-is-the-size-of-bitset-in-c
Обсуждают сегодня