union一个有趣的应用
生活随笔
收集整理的這篇文章主要介紹了
union一个有趣的应用
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
今天在讀《Linux高性能服務器編程》時看到一個有趣的東西。書中用了一個特別的方法去求字節(jié)序。我們知道字節(jié)序分為大端和小端,大端就是數(shù)據(jù)的高位字節(jié)存儲在內(nèi)存的低地址處,小段則反之。那么我們怎么知道我們的電腦是大端還是小端呢,這本書告訴我們可以利用union的特性,union里面的變量都是共享內(nèi)存的,我們只需要將一個比如int類型的數(shù)據(jù)和一個數(shù)組union在一起,賦值那個int數(shù)據(jù),然后看看數(shù)組的高位和低位分別是什么就知道了。
int main(){union{short value;char union_bytes[sizeof(short)];}test;test.value=0x0102;short a=test.union_bytes[0];cout<<a;if(test.union_bytes[0]==1&&test.union_bytes[1]==2)cout<<"big endian"<<endl;else if(test.union_bytes[0]==2&&test.union_bytes[1]==1)cout<<"little endian"<<endl;else cout<<"unknown..."; }自從知道有大端小端這個東西的時候一直有個疑問,為什么在設(shè)計上不進行統(tǒng)一呢。出各種各樣的標準統(tǒng)一接口不是計算機行業(yè)的人經(jīng)常做的嗎哈哈哈哈哈。我給出的解釋方式是或許在不同的設(shè)備功能不一樣,不同的方式可以更好的適應吧。
well,既然不同了那在進行網(wǎng)絡傳輸中如果不統(tǒng)一就會出大問題的。所以Linux給我們提供了4個函數(shù)來完成主機字節(jié)序和網(wǎng)絡字節(jié)序的轉(zhuǎn)換,現(xiàn)在網(wǎng)絡字節(jié)序通常是大端。
unsigned long int htonl(unsigned long int hostlong); unsigned short int htons(unsigned short int hostshort); unsigned long int ntohl(unsigned long int netlong); unsigned short int ntohs(unsigned short int netshort);總結(jié)
以上是生活随笔為你收集整理的union一个有趣的应用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 从(0,0)到(n,n)——广度优先及其
- 下一篇: 迭代器源码解析