Linux进程间通信方式:实现数据共享(linux进程通信方式)
Linux进程间通信是进程间实现数据传输和数据共享的一种跨进程间的接口,如果可以使用非标准方法实现,就可以快速完成进程间通信。Linux操作系统为进程间提供了多种通信方式实现数据共享,主要包括管道通信(Pipes)、命名管道(Named Pipes)、信号(Signals)、消息队列(Message Queues)、共享内存(Shared Memory)和信号量(Semaphore)等。
一、管道通信(Pipes)
管道通信是Linux中最基本的进程间通信模型,它允许进程之间两个方向上数据传输,是半双工的,而且只能在父子进程间通信(即调用进程和被调用进程)。使用管道通信可以用下列代码实现:
int pipefd[2];
if(pipe(pipefd)
{
printf(“create pipe error!\n”);
return -1;
}
二、命名管道(Named Pipes)
命名管道使用文件系统来实现,它可以实现不同进程间的通信,改进了管道的双向的半双工的通信模式,允许多个进程读写管道,可以实现全双工的数据通信,但是它取决于系统调用现有的文件结构来实现,所以使用时也较为繁琐,使用代码如下:
int main()
{
int fd;
char * myfifo = “/tmp/myfifo”;
mkfifo(myfifo, 0666);
fd = open(myfifo, O_RDONLY);
read(fd, data_from_server, sizeof(data_from_server));
close(fd);
unlink(myfifo);
return 0;
}
三、信号(Signals)
信号是Linux操作系统中一种同步机制,可以在任何进程间传递,用来唤醒目标进程,由于信号可能会被系统忽略或者阻止,所以信号只能用来传递一些小段的数据,平时也比较少用到,使用代码如下:
#include
void sig_handler(int signo)
{
if (signo == SIGINT)
{
printf(“recv SIGINT\n”);
}
}
int main(int argc, char *argv[])
{
//安装信号处理函数
signal(SIGINT, sig_handler);
while(1)
{
sleep(1);
}
return 0;
}
四、消息队列(Message Queues)
消息队列是用来实现线程间或进程间数据共享的重要手段,它主要用来在系统中传递小段的数据,可以有效缓解进程繁重的工作负荷,使用代码如下:
#include
//消息缓冲区
struct msgbuf
{
long mtype;
char mtext[256];
};
int main()
{
int msgid;
int ret;
struct msgbuf buf;
msgid = msgget(0x1234, IPC_CREAT|0666);
if(msgid
{
printf(“msgget() error!\n”);
return -1;
}
while(1)
{
//接收消息队列
ret = msgrcv(msgid, &buf, 256, 0, IPC_NOWAIT);
if(ret > 0)
{
printf(“receive:%s\n”, buf.mtext);
}
sleep(2);
}
return 0;
}
五、共享内存(Shared Memory)
共享内存是进程间最高效方式之一,它可以用来实现进程间大量数据的快速传输,因为它就是一个物理内存区域,多个进程可以访问它,操作系统会维护它的一致性,使用代码如下:
#include
int main()
{
int shmid;
void * shmaddr;
if((shmid = shmget(IPC_PRIVATE, 1024, IPC_CREAT))
{
perror(“shmget() error!\n”);
return -1;
}
if((shmaddr = shmat(shmid, 0, 0)) == (void *)-1)
{
perror(“shmat() error!\n”);
return -1;
}
//利用共享内存完成数据传递
memcpy(shmaddr, data, 1024);
shmdt(shmaddr);
shmctl(shmid, IPC_RMID, 0);
return