socketpair服務器
socketpair:相比較以前提到的管道,socketpair是一個全雙工的通訊方式,它的一端便可以讀也能夠寫,對於它我是這樣理解的:網絡
假設如今咱們是在本地使用socketpair的,客戶端爲fd[0],服務器端爲fd[1],當服務器向客戶端寫數據時,從fd[1]的寫端寫入數據,而從fd[1]的讀端讀取數據,反之從客戶端上的操做也是如此。dom
下面是實現的一個socketpair版本地進程間通訊socket
#include <sys/types.h> /* See NOTES */ #include <sys/socket.h> int socketpair(int domain, int type, int protocol, int sv[2]);
domian爲操做的方式,由於咱們是本地因此用AF_LOCAL。tcp
type爲傳輸方式,咱們採用tcp的流式服務,SOCK_STREAM。ide
protocol爲控制,咱們選擇默認填0,進程
sv爲要建立多少個文件描述符,注意(這個文件描述符是網絡文件描述符,能夠說他是虛擬的)。string
1 #include<stdio.h> 2 #include<sys/types.h> 3 #include<sys/socket.h> 4 #include<unistd.h> 5 #include<string.h> 6 int main() 7 { 8 int fd[2]; 9 if(socketpair(AF_LOCAL,SOCK_STREAM,0,fd)<0) 10 { 11 perror("socketpair"); 12 } 13 char buf[1024]; 14 pid_t id=fork(); 15 if(id<0){ 16 perror("fork"); 17 }else if(id==0){ 18 close(fd[0]); 19 while(1) 20 { 21 sleep(1); 22 memset(buf,'\0',sizeof(buf)-1); 23 strcpy(buf,"child hello world"); 24 write(fd[1],buf,strlen(buf)+1); 25 ssize_t size=read(fd[1],buf,sizeof(buf)-1); 26 if(size>0) 27 { 28 buf[size]='\0'; 29 printf("parents say::%s\n",buf); 30 } 31 } 32 close(fd[1]); 33 } 34 else{ 35 close(fd[1]); 36 while(1) 37 { 38 sleep(2); 39 ssize_t size=read(fd[0],buf,sizeof(buf)-1); 40 if(size>0) 41 { 42 buf[size]='\0'; 43 printf("child say::%s\n",buf); 44 } 45 memset(buf,'\0',sizeof(buf)); 46 strcpy(buf,"parent hello world"); 47 write(fd[0],buf,strlen(buf)+1); 48 } 49 close(fd[0]); 50 51 } 52 53 return 0; 54 }
socketpair實現了全雙工的通訊方式。it