。
我有一个DWORD
,例如:0x0A0B0C0D
。我想获得0x0D0C0B0A
.
我通常使用 BSWAP
汇编指令,但我使用的编译器不支持内置汇编。
这个编译器是什么? 如今,大多数体面的编译器都支持bswap内部函数,GCC在这里有一些解决方案,或者普通的内置列表。
MSVC 在其 RTL(优化为内在形式)中_byteswap_*
,ICC 包括_bswap*
内联
new_dword = (dword & 0x000000ff) << 24 | (dword & 0x0000ff00) << 8 |
(dword & 0x00ff0000) >> 8 | (dword & 0xff000000) >> 24;
您可以使用例如 htonl
,如果你不想自己做一点点扭动。
http://www.cplusplus.com/forum/beginner/2563/
考虑一个手动对位重新排序的例程。
与可能不适合您需求的替代方案相比,这几乎可以保证最慢。
#include <iostream>
#include <limits.h>
unsigned int rearrange(unsigned int val);
int main() {
unsigned int a = 0xa0b0c0d0;
std::cout << std::hex << std::showbase
<< a << 'n'
<< rearrange(a) << std::endl;
}
unsigned int rearrange(unsigned int val) {
return (val & 0xff000000) >> CHAR_BIT * 3 |
(val & 0x00ff0000) >> CHAR_BIT |
(val & 0x0000ff00) << CHAR_BIT |
(val & 0x000000ff) << CHAR_BIT * 3;
}
输出
0xa0b0c0d0
0xd0c0b0a0