您好,登錄后才能下訂單哦!
socketpair
socketpair:相比較之前提到的管道,socketpair是一個全雙工的通信方式,它的一端即可以讀也可以寫,對于它我是這樣理解的:
假設現在我們是在本地使用socketpair的,客戶端為fd[0],服務器端為fd[1],當服務器向客戶端寫數據時,從fd[1]的寫端寫入數據,而從fd[1]的讀端讀取數據,反之從客戶端上的操作也是如此。
下面是實現的一個socketpair版本地進程間通信
#include <sys/types.h> /* See NOTES */ #include <sys/socket.h> int socketpair(int domain, int type, int protocol, int sv[2]);
domian為操作的方式,因為我們是本地所以用AF_LOCAL。
type為傳輸方式,我們采用tcp的流式服務,SOCK_STREAM。
protocol為控制,我們選擇默認填0,
sv為要創建多少個文件描述符,注意(這個文件描述符是網絡文件描述符,可以說他是虛擬的)。
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實現了全雙工的通信方式。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。