Сообщение bit_cast от 18.06.2016 13:13
Изменено 27.06.2016 18:10 S. Schlongberg
bit_cast
Здравствуйте, T4r4sB, Вы писали:
TB>memmove позволяет битово копировать данные разных типов без УБЭ. Но от огребания от индейца не спасёт, как уже сказали.
Похоже, memcpy/memmove самый годный способ. Clang, GCC и MSVC его оптимизируют на mov. Хотя, окончательное решение, что использовать, буду принимать на основе бенчмарков.
В проекте Chromium даже есть функция bit_cast, которая именно так и сделана.
https://chromium.googlesource.com/chromium/src/+/1587f7d/base/macros.h#76
А вот с memmove еще интересней. Согласно пунктам 3.9.2 и 3.9.3 стандарта C++ 14, получается, я могу сделать так:
То есть обход strict aliasing rule заключается в вызове ничего не делающей memmove.
Update: Хотя нет, не получается. Там написано:
For any trivially copyable type T, if two pointers to T point to distinct T objects obj1 and obj2
А у меня объекты-то не различные.
TB>memmove позволяет битово копировать данные разных типов без УБЭ. Но от огребания от индейца не спасёт, как уже сказали.
Похоже, memcpy/memmove самый годный способ. Clang, GCC и MSVC его оптимизируют на mov. Хотя, окончательное решение, что использовать, буду принимать на основе бенчмарков.
В проекте Chromium даже есть функция bit_cast, которая именно так и сделана.
https://chromium.googlesource.com/chromium/src/+/1587f7d/base/macros.h#76
template <class Dest, class Source>
inline Dest bit_cast(const Source& source) {
COMPILE_ASSERT(sizeof(Dest) == sizeof(Source), VerifySizesAreEqual);
Dest dest;
memcpy(&dest, &source, sizeof(dest));
return dest;
}А вот с memmove еще интересней. Согласно пунктам 3.9.2 и 3.9.3 стандарта C++ 14, получается, я могу сделать так:
template <class Dest, class Source>
inline Dest& bit_cast(Source& source) {
// Проверки
return *((Dest*)std::memmove(&source, &source, sizeof(Dest)));
}То есть обход strict aliasing rule заключается в вызове ничего не делающей memmove.
Update: Хотя нет, не получается. Там написано:
For any trivially copyable type T, if two pointers to T point to distinct T objects obj1 and obj2
А у меня объекты-то не различные.