C/C++测试代码 #include <iostream> int main(int argc, char* argv[]) { int n = 0x11223344; int i = 0; for( i = 0; i < 4; i++) { printf("%02x", *(((char*)&n)+i)); } printf("\n"); return 0; } Centos 5.3 + 4.1.2 编译命令:g++ ytest.cpp -o test.ex 44 33 22 11 WinXP + VS2003测试结果 编译命令:cl ytest.cpp 44 33 22 11 Java测试代码 要特别注意的是,移位操作并不是内存移位,而是数字的字面移位,如下代码无论在何种操作系统,何种语言,结果将是一样 所以以下代码只适用于Java int x = 0x11223344; System.out.printf("%02x ", 0xFF&(x>>24)); System.out.printf("%02x ", 0xFF&(x>>16)); System.out.printf("%02x ", 0xFF&(x>>8)); System.out.printf("%02x", 0xFF&x); 不同的CPU有不同的字节序类型,这些字节序是指整数在内存中保存的顺序。 最常见的有两种: 1. Little-endian:将低序字节存储在起始地址(低位编址) 2. Big-endian:将高序字节存储在起始地址(高位编址) LE(little-endian): 最符合人的思维的字节序 地址低位存储值的低位 地址高位存储值的高位 怎么讲是最符合人的思维的字节序,是因为从人的第一观感来说 低位值小,就应该放在内存地址小的地方,也即内存地址低位 反之,高位值就应该放在内存地址大的地方,也即内存地址高位 BE(big-endian): 最直观的字节序 地址低位存储值的高位 地址高位存储值的低位 为什么说直观,不要考虑对应关系 只需要把内存地址从左到右按照由低到高的顺序写出 把值按照通常的高位到低位的顺序写出 两者对照,一个字节一个字节的填充进去 例子1:在内存中双字0x01020304(DWORD)的存储方式。 内存地址 4000 4001 4002 4003 LE 04 03 02 01 BE 01 02 03 04 注:每个地址存1个字节,每个字有4个字节。2位16进制数是1个字节(0xFF=11111111)。 例子2:如果我们将0x1234abcd写入到以0x0000开始的内存中,则结果为 big-endian little-endian 0x0000 0x12 0xcd 0x0001 0x23 0xab 0x0002 0xab 0x34 0x0003 0xcd 0x12 x86系列的CPU都是little-endian的字节序。