[Linux网络编程学习笔记]套接字地址结构
                                                            生活随笔
收集整理的這篇文章主要介紹了
                                [Linux网络编程学习笔记]套接字地址结构
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.                        
                                好久沒有看那Linux網絡編程這本書了,今天看到了重點部分—TCP套接字。下面先來看看套接字的地址結構
Linux系統的套接字可以支持多種協議,每種不同的協議都是用不同的地址結構。在頭文件<linux/socket.h>中有一個這樣的老式結構(現在一般不使用這個結夠了)。
struct sockaddr{ unsigned short sa_family; //套接字的協議簇地址類型,TCP/IP協議對于IPv4地址類型為AF_INET char sa_data[14];//存儲具體的協議地址};現在一般使用下面這個sockaddr_in結構(用來設置/獲取地址信息):
struct sockaddr_in{ unsigned short sin_len;????? //IPv4地址長度 short int????? sin_family;?? //指代協議簇,在TCP套接字編程只能是AF_INET unsigned short sin_port;???? //存儲端口號(使用網絡字節順序),數據類型是一個16為的無符號整形類型 struct???????? in_addr sin_addr;//存儲IP地址,IP地址是一個in_add結構體(結構在下面) unsigned char? sin_zero[8];???? //為了讓sockaddr與sockaddr_in兩個數據結構保持大小相同而保留的空字節};其中,in_addr這個數據結構:
struct in_addr{ unsigned long s_addr;?? //按照網絡字節順序存儲IP地址};在現在很火的IPv6中套接字地址結構使用了下面這個結構體(結構中的成員是有序排列的):
#DEFINE SIN6_LENstruct sockaddr_in6{ unsigned short int sin6_len;?? //IPv6結構長度,是一個無符號的8為整數,表示128為IPv6地址長度short int sin6_family; //地址類型AF_INET6
unsigned short int sin6_port; //存儲端口號,按網絡字節順序
unsigned short int sin6_flowinfo;? //低24位是流量標號,然后是4位的優先級標志,剩下四位保留 struct in6_addr sin6_addr;????? //IPv6地址,網絡字節順序}; struct in6_addr{ unsigned long s6_addr;? //128位的IPv6地址,網絡字節順序};好了,看個例子更好說明這些結構體的應用,下面以IPv4為例:
struct sockaddr_in mysock;mysock.sin_family = AF_INET; //TCP地址結構mysock.sin_port = htons(3490); //字節順序轉換函數(后面我會介紹的)mysock.sin_addr.s_addr = inet_addr("166.111.160.10");//設置IP地址bzero(&(mysock.sin_zero),8);//設置sin_zero為8位保留字節//如果mysock.sin_addr.s_addr = INADDR_ANY,則不指定IP地址(用于server程序)一些基本的函數:
IP地址轉換函數:inet_addr()和inet_ntoa()
格式:
unsigned long inet_addr(const char *cp);char* inet_ntoa(struct in_addr in);總結
以上是生活随笔為你收集整理的[Linux网络编程学习笔记]套接字地址结构的全部內容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: sfdisk命令的使用技巧
- 下一篇: EF 4.1中内部经常提交的 exec
