Мне нужно интерпретировать 4 байта в начале (или по некоторому 4-байтовому выровненному смещению) необработанного буфера, отображаемого в памяти, как целое число.
"Классический способ" с reinterpret_cast - это неопределенное поведение. Ниже приведены три альтернативы, которые скомпилированы в один и тот же ассемблерный код с помощью gcc и clang, см. https://godbolt.org/z/13fsTqfxq.
Какой способ (в C++20) является «лучшим», каковы плюсы и минусы? (при условии, что компилятор поддерживает все параметры)
Будет ли ответ другим, если буфер будет объявлен нестабильным?
#include
#include
#include
#include
#include
extern unsigned char * buffer; // page aligned
uint32_t read_reinterpret_cast()
{
return *reinterpret_cast( buffer );
}
uint32_t read_reinterpret_launder()
{
return * std::launder( reinterpret_cast( buffer ) );
}
uint32_t read_bit_cast()
{
uint32_t * t = reinterpret_cast( buffer );
return std::bit_cast( *t );
}
#if __cpp_lib_start_lifetime_as
uint32_t read_start_lifetime_as()
{
return *std::start_lifetime_as(buffer); // C++23
}
#endif
uint32_t read_memcpy()
{
uint32_t t = {};
memcpy( &t, buffer, sizeof(uint32_t) );
return t;
}
Подробнее здесь: https://stackoverflow.com/questions/798 ... egers-from