socketpair

更新时间:2024-02-28 20:41

socketpair,套接字可以用于网络通信,也可以用于本机内的进程通信

术语简介

套接字可以用于网络通信,也可以用于本机内的进程通信。由于本机内进程的IP地址都相同,因此只需要进程号来确定通信的双方。非网络通信套接字在Linux环境中的应用很多,最典型的就是Linux的桌面系统——Xserver,其就是使用非网络套接字的方法进行进程之间的通信的。

Linux环境下使用socketpair函数创造一对未命名的、相互连接的UNIX域套接字。

定义

int socketpair(int d, int type, int protocol, int sv[2]);描述

建立一对匿名的已经连接的套接字

socketpair函数概要如下:

#include

#include

int socketpair(int domain, int type, int protocol, int sv[2]);

sys/types.h文件需要用来定义一些C宏常量。sys/socket.h文件必须包含进来定义socketpair函数原型。

socketpair函数需要四个参数。他们是:

套接口的域

套接口类型

使用的协议

指向存储文件描述符的指针

类型参数声明了我们希望创建哪种类型的套接口。socketpair函数的选择如下:

SOCK_STREAM

SOCK_DGRAM

对于socketpair函数,protocol参数必须提供为0。

参数sv[2]是接收代表两个套接口的整数数组。每一个文件描述符代表一个套接口,并且与另一个并没有区别。

如果函数成功,将会返回0值。否则将会返回-1表明创建失败,并且errno来表明特定的错误号。

关于流程。socketpair()函数创建出两个进程,fork()之后这两个进程都会执行主程序中的代码,这个一定要注意!尤其是bind的时候,如果bind两次的话,那就会出错了。一般会在子进程里调用一个带死循环的函数,这样就好了。

新建一对socket

int sockets[2];

if (socketpair(AF_UNIX, SOCK_STREAM, 0, sockets)<0) {

printf

}

socketpair实现父子进程双工通信

#include

#include

#include

#include

#include

void err_sys(const char *errmsg);

int main(void)

{

int sockfd[2];

pid_t pid;

if ((socketpair(AF_LOCAL, SOCK_STREAM, 0, sockfd))<0)

if ((pid = fork()) == -1)

else if (pid == 0)

{ /* child process */

char s[BUFSIZ];

ssize_t n;

close(sockfd[1]); //write port

if ((n = read(sockfd[0], s, sizeof(s))) <0)

printf

close(sockfd[0]);

exit(0);

}

else if (pid>0)

{ /* parent process */

ssize_t n;

close(sockfd[0]); //read port

if((n = write(sockfd[1], buf, sizeof(buf)))<0)

close(sockfd[1]);

wait(NULL);

}

return 0;

}

void err_sys(const char *errmsg)

{

perror(errmsg);

exit(1);

}

免责声明
隐私政策
用户协议
目录 22
0{{catalogNumber[index]}}. {{item.title}}
{{item.title}}