原博客地址:http://www.cnblogs.com/hanxi/archive/2011/05/26/2059307.html
[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_LEN
struct 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);
作者:涵曦(www.hanxi.info)
微博:t.qq.com/hanxi1203
出處:hanxi.cnblogs.com
GitHub:github.com/hanxi