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