进程之间的通讯使用很频繁,在本地主机上两个不同的进程之间需要通讯时,我们可以采用unix域套接字来通讯,虽然因特网域套接字也可以达到同一目的,但是unix域套接字效率更高,主要体现如下:
(1)UNIX域套接字仅仅复制数据
(2)不像因特网域的套接字,它不需要处理协议,不需要产生顺序号,不需要发送确认报文,不需要添加或者删除网络头部,无需计算校验和。
UNIX域套接字用于同一台主机上的进程间通讯时,提供了STREAM和DIAGRAM两种,UNIX域的数据服务是可靠的,既不会丢失也不会传错。
非命令的UNIX域套接字只能用于亲缘关系的父子进程之间通讯:
为了创建一对非命名的,相互连接的UNXI域套接字,用户可以使用socketpair函数
参数介绍:
第1个参数d(domain),表示协议族,只能为AF_LOCAL或者AF_UNIX;
第2个参数type,表示类型,只能为0。
第3个参数protocol,表示协议,可以是SOCK_STREAM或者SOCK_DGRAM。用SOCK_STREAM建立的套接字对是管道流,与一般的管道相区别的是,套接字对建立的通道是双向的,即每一端都可以进行读写。不管是数据流还是数据报协议,unix域套接字都是可靠的,不丢包的。
第4个参数sv,用于保存建立的套接字对。
示例代码如下
#include <stdio.h>
#include <stdlib.h>
#include <sys/socket.h>
#include <string.h>
#include <sys/types.h>
#include <unistd.h>
int main(void)