| 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字節協(xié)議地址。 此數據結構用做bind、connect、recvfrom、sendto等函數的參數,指明地址信息。 但一般編程中并不直接針對此數據結構操作,而是使用另一個(gè)與sockaddr等價(jià)的數據結構 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)絡(luò )字節順序) sin_addr存儲IP地址,使用in_addr這個(gè)數據結構 sin_zero是為了讓sockaddr與sockaddr_in兩個(gè)數據結構保持大小相同而保留的空字節。 s_addr按照網(wǎng)絡(luò )字節順序存儲IP地址 sockaddr_in和sockaddr是并列的結構,指向sockaddr_in的結構體的指針也可以指向 sockadd的結構體,并代替它。也就是說(shuō),你可以使用sockaddr_in建立你所需要的信息, 在最后用進(jìn)行類(lèi)型轉換就可以了bzero((char*)&mysock,sizeof(mysock));//初始化 mysock結構體名 mysock.sa_family=AF_INET; mysock.sin_addr.s_addr=inet_addr("192.168.0.1"); …… 等到要做轉換的時(shí)候用: (struct sockaddr*)mysock sa_data的含義是由sa_family決定 如果sa_family=AF_INET 則sa_data就是sockaddr_in的sin_addr和sin_port 換句話(huà)說(shuō),這時(shí)sockaddr可以當作sockaddr_in看 Sockfd是調用socket函數返回的socket描述符,my_addr是個(gè)指向包含有本機IP地址及端口號等信息的sockaddr類(lèi)型的指 針;addrlen常被設置為sizeof(struct sockaddr)。 structsockaddr結構類(lèi)型是用來(lái)保存socket信息的: struct sockaddr { unsigned short sa_family; /* 地址族, AF_xxx */ char sa_data[14]; /* 14 字節的協(xié)議地址 */ }; sa_family一般為AF_INET,代表Internet(TCP/IP)地址族; sa_data則包含該socket的IP地址和端口號。 另外更有一種結構類(lèi)型: struct sockaddr_in { short int sin_family; /* 地址族 */ unsigned short int sin_port; /* 端口號 */ struct in_addr sin_addr;/* IP地址 */ unsigned char sin_zero[8]; /* 填充0 以保持和struct sockaddr同樣大小*/ }; 這個(gè)結構更方便使用。sin_zero用來(lái)將sockaddr_in結構填充到和struct sockaddr同樣的長(cháng)度,能用bzero()或memset()函數將其置為零。指向sockaddr_in的指針和指向sockaddr的指針能相互轉換,這意味著(zhù)如果一個(gè)函數所需參數類(lèi)型是sockaddr時(shí),你能在函數調用的時(shí)候將一個(gè)指向 sockaddr_in的指針轉換為指向sockaddr的指針;或相反。 |
聯(lián)系客服