[转]判断大端小端
轉自:http://blog.csdn.net/hongjiujing/article/details/2173909
int i=1;??
??? char *p=(char *)&i;??
? ? if(*p==1)????
????????? ?printf("1");?
?? ?else
????????? ?printf("2");
????????? 大小端存儲問題,如果小端方式中(i占至少兩個字節的長度)則i所分配的內存最小地址那個字節中就存著1,其他字節是0.大端的話則1在i的最高地址字節 處存放,char是一個字節,所以強制將char型量p指向i則p指向的一定是i的最低地址,那么就可以判斷p中的值是不是1來確定是不是小端。
請寫一個C函數,若處理器是Big_endian的,則返回0;若是Little_endian的,則返回1 解答: int checkCPU( ) { { union w {?? int a; char b; } c; c.a = 1; return(c.b ==1); } } 剖析: 嵌入式系統開發者應該對Little-endian和Big-endian模式非常了解。采用Little-endian模式的CPU對操作數 的存放方式是從低字節到高字節,而Big-endian模式對操作數的存放方式是從高字節到低字節。例如,16bit寬的數0x1234在Little- endian模式CPU內存中的存放方式(假設從地址0x4000開始存放)為:| 內存地址 | 0x4000 | 0x4001 |
| 存放內容 | 0x34 | 0x12 |
| 內存地址 | 0x4000 | 0x4001 |
| 存放內容 | 0x12 | 0x34 |
| 內存地址 | 0x4000 | 0x4001 | 0x4002 | 0x4003 |
| 存放內容 | 0x78 | 0x56 | 0x34 | 0x12 |
| 內存地址 | 0x4000 | 0x4001 | 0x4002 | 0x4003 |
| 存放內容 | 0x12 | 0x34 | 0x56 | 0x78 |
轉載于:https://www.cnblogs.com/zhiyzhan/archive/2011/10/23/2221577.html
總結
- 上一篇: hashCode与equals的区别与联
- 下一篇: vsftp 在pasv下的防火墙配置