linux 網絡編程相關結構體

原博客地址: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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章