struct sockaddr 是一個通用地址結(jié)構(gòu),這是為了統(tǒng)一地址結(jié)構(gòu)的表示方法,統(tǒng)一接口函數(shù),使不同的地址結(jié)構(gòu)可以被bind() , connect() 等函數(shù)調(diào)用;struct sockaddr_in中的in 表示internet,就是網(wǎng)絡地址,這只是我們比較常用的地址結(jié)構(gòu),屬于AF_INET地址族,他非常的常用,以至于我們都開始討論它與 struct sockaddr通用地址結(jié)構(gòu)的區(qū)別。另外還有struct sockaddr_un 地址結(jié)構(gòu),剩下的地址結(jié)構(gòu)我就不知道了。我們可以認為 struct sockaddr_in 和 struct sockaddr_un 是 struct sockaddr 的子集。
struct sockaddr {
unsigned short sa_family; /* address family, AF_xxx */ char sa_data[14]; /* 14 bytes of protocol address */ }; 里的sa_data里的IP地址取出來,折騰半天還是失敗了。在CSDN上發(fā)現(xiàn)2003年時曾有人跟我一樣傻 哈哈 struct sockaddr { unsigned short sa_family; /* address family, AF_xxx */ char sa_data[14]; /* 14 bytes of protocol address */ }; sa_family是地址家族,一般都是“AF_xxx”的形式。好像通常大多用的是都是AF_INET。 sa_data是14字節(jié)協(xié)議地址。 此數(shù)據(jù)結(jié)構(gòu)用做bind、connect、recvfrom、sendto等函數(shù)的參數(shù),指明地址信息。 但一般編程中并不直接針對此數(shù)據(jù)結(jié)構(gòu)操作,而是使用另一個與sockaddr等價的數(shù)據(jù)結(jié)構(gòu) sockaddr_in(在netinet/in.h中定義): struct sockaddr_in { short int sin_family; /* Address family */ unsigned short int sin_port; /* Port number */ struct in_addr sin_addr; /* Internet address */ unsigned char sin_zero[8]; /* Same size as struct sockaddr */ }; struct in_addr { unsigned long s_addr; }; typedef struct in_addr { union { struct{ unsigned char s_b1, s_b2, s_b3, s_b4; } S_un_b; struct { unsigned short s_w1, s_w2; } S_un_w; unsigned long S_addr; } S_un; } IN_ADDR; sin_family指代協(xié)議族,在socket編程中只能是AF_INET sin_port存儲端口號(使用網(wǎng)絡字節(jié)順序) sin_addr存儲IP地址,使用in_addr這個數(shù)據(jù)結(jié)構(gòu) sin_zero是為了讓sockaddr與sockaddr_in兩個數(shù)據(jù)結(jié)構(gòu)保持大小相同而保留的空字節(jié)。 s_addr按照網(wǎng)絡字節(jié)順序存儲IP地址 sockaddr_in和sockaddr是并列的結(jié)構(gòu),指向sockaddr_in的結(jié)構(gòu)體的指針也可以指向 sockadd的結(jié)構(gòu)體,并代替它。也就是說,你可以使用sockaddr_in建立你所需要的信息, 在最后用進行類型轉(zhuǎn)換就可以了bzero((char*)&mysock,sizeof(mysock));//初始化 mysock結(jié)構(gòu)體名 mysock.sa_family=AF_INET; mysock.sin_addr.s_addr=inet_addr("192.168.0.1"); …… 等到要做轉(zhuǎn)換的時候用: (struct sockaddr*)mysock |
|
來自: fym0121 > 《Linux進程通信》