在linux下,使用socketpair函数能够创建一对套节字进行进程或线程间通信。
参数1(domain):表示协议族,在Linux下只能为AF_LOCAL或者AF_UNIX。(自从Linux 2.6.27后也支持SOCK_NONBLOCK和SOCK_CLOEXEC)
参数2(type):表示协议,可以是SOCK_STREAM或者SOCK_DGRAM。SOCK_STREAM是基于TCP的,而SOCK_DGRAM是基于UDP的
参数3(protocol):表示类型,只能为0
参数4(sv[2]):套节字柄对,该两个句柄作用相同,均能进行读写双向操作
返回结果: 0为创建成功,-1为创建失败,并且errno来表明特定的错误号,具体错误号如下所述:
EAFNOSUPPORT:本机上不支持指定的address。
EFAULT: 地址sv无法指向有效的进程地址空间内。
EMFILE: 已经达到了系统限制文件描述符,或者该进程使用过量的描述符。
EOPNOTSUPP:指定的协议不支持创建套接字对。
EPROTONOSUPPORT:本机不支持指定的协议。
该函数只能用于UNIX域(LINUX)下。
只能用于有亲缘关系的进程(或线程)间通信。
所创建的套节字对作用是一样的,均能够可读可写(而管道PIPE只能进行单向读或写)。
在读的时候,管道内必须有内容,否则将会阻塞;简而言之,该函数是阻塞的。
int main(int argc, char* argv[]){
char buf[128] = {0};
int socket_pair[2];
pid_t pid;
if(socketpair(AF_UNIX, SOCK_STREAM, 0, socket_pair) == -1 ) {
printf("Error, socketpair create failed, errno(%d): %s\n", errno, strerror(errno));
return EXIT_FAILURE;
}
int size = write(socket_pair[0], str, strlen(str));
//可以读取成功;
read(socket_pair[1], buf, size);
printf("Read result: %s\n",buf);
return EXIT_SUCCESS;
}
void testfd(){ int data_fd[2] = {0}; if (-1 == socketpair(AF_UNIX, SOCK_DGRAM, 0, data_fd)) { } int buf_size = SOCKET_BUFFER_SIZE; int ret = 0; ret = setsockopt(data_fd[0], SOL_SOCKET, SO_SNDBUF, &buf_size, sizeof(buf_size)); ret = setsockopt(data_fd[0], SOL_SOCKET, SO_RCVBUF, &buf_size, sizeof(buf_size)); ret = setsockopt(data_fd[1], SOL_SOCKET, SO_SNDBUF, &buf_size, sizeof(buf_size)); ret = setsockopt(data_fd[1], SOL_SOCKET, SO_RCVBUF, &buf_size, sizeof(buf_size)); int flags = fcntl(data_fd[0], F_GETFL); flags |= O_NONBLOCK; if (fcntl(data_fd[0], F_SETFL, flags)) { } }