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字節協議地址。
此數據結構用作bind、connect、recvfrom、sendto等函數的參數,指明地址信息。編程
但通常編程中並不直接針對此數據結構操做,而是使用另外一個與sockaddr等價的數據結構網絡
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指代協議族,在socket編程中只能是AF_INET
sin_port存儲端口號(使用網絡字節順序)
sin_addr存儲IP地址,使用in_addr這個數據結構
sin_zero是爲了讓sockaddr與sockaddr_in兩個數據結構保持大小相同而保留的空字節。
s_addr按照網絡字節順序存儲IP地址數據結構
sockaddr_in和sockaddr是並列的結構,指向sockaddr_in的結構體的指針也能夠指向
sockadd的結構體,並代替它。也就是說,你可使用sockaddr_in創建你所須要的信息,
在最後用進行類型轉換就能夠了bzero((char*)&mysock,sizeof(mysock));//初始化
mysock結構體名
mysock.sa_family=AF_INET;
mysock.sin_addr.s_addr=inet_addr("192.168.0.1");
……
等到要作轉換的時候用:
(struct sockaddr*)mysocksocket
進程間通訊的一種方式是使用UNIX套接字,人們在使用這種方式時每每用的不是網絡套接字,而是一種稱爲本地套接字的方式。這樣作能夠避免爲黑客留下後門。函數
建立
使用套接字函數socket建立,不過傳遞的參數與網絡套接字不一樣。域參數應該是PF_LOCAL或者PF_UNIX,而不能用PF_INET之類。本地套接字的通信類型應該是SOCK_STREAM或SOCK_DGRAM,協議爲默認協議。例如:
int sockfd;
sockfd = socket(PF_LOCAL, SOCK_STREAM, 0);spa
綁定
建立了套接字後,還必須進行綁定才能使用。不一樣於網絡套接字的綁定,本地套接字的綁定的是struct sockaddr_un結構。struct sockaddr_un結構有兩個參數:sun_family、sun_path。sun_family只能是AF_LOCAL或AF_UNIX,而 sun_path是本地文件的路徑。一般將文件放在/tmp目錄下。例如:指針
struct sockaddr_un sun; sun.sun_family = AF_LOCAL; strcpy(sun.sun_path, filepath); bind(sockfd, (struct sockaddr*)&sun, sizeof(sun));
監聽
本地套接字的監聽、接受鏈接操做與網絡套接字相似。code
鏈接
鏈接到一個正在監聽的套接字以前,一樣須要填充struct sockaddr_un結構,而後調用connect函數。進程
鏈接創建成功後,咱們就能夠像使用網絡套接字同樣進行發送和接受操做了。甚至還能夠將鏈接設置爲非阻塞模式,這裏就不贅述了。io