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