我只是想问一下我的方法从小端转换到大端是否正确,只是为了确保我是否理解其中的区别。
我有一个以小端序存储的数字,这里是数字的二进制和十六进制表示:
0001 0010 0011 0100 0101 0110 0111 1000
12345678
在大端格式中,我认为应该交换字节,如下所示:
1000 0111 0110 0101 0100 0011 0010 0001
87654321
这个对吗?
此外,下面的代码尝试执行此操作但失败了。有什么明显的错误或者我可以优化一些东西吗?如果代码不适合此转换,您能否解释原因并展示执行相同转换的更好方法?
uint32_t num = 0x12345678;
uint32_t b0,b1,b2,b3,b4,b5,b6,b7;
uint32_t res = 0;
b0 = (num & 0xf) << 28;
b1 = (num & 0xf0) << 24;
b2 = (num & 0xf00) << 20;
b3 = (num & 0xf000) << 16;
b4 = (num & 0xf0000) << 12;
b5 = (num & 0xf00000) << 8;
b6 = (num & 0xf000000) << 4;
b7 = (num & 0xf0000000) << 4;
res = b0 + b1 + b2 + b3 + b4 + b5 + b6 + b7;
printf("%d\n", res);