Linux进程间通信

     一般情况下,Linux操作系统下进程间的通信包括单个计算机进程以及多个计算机之间进程的通信。从早期的UNIX IPC(管道,FIFO,信号),发展到SYSTEM V IPC(System V 消息队列、System V 信号灯、System V 共享内存区),后来又到了Posix IPC(:Posix 消息队列、Posix 信号灯、Posix 共享内存区),在这些不同的Unix版本,可能有自己的标准,这里只讨论广泛运用的遵循Posix 标准的Linux版本进程间的通信。

管道(pipe)及有名管道(FIFO):管道是具有亲缘关系进程间的通信,而有名管道突破了限制,支持不具有亲缘关系的进程间通信。亲缘关系是指父进程和子进程或者子进程和子进程之间;管道之间通信是半双工的,即数据只能从一个方向流动,管道的一端只能写,另一端只能读;管道的大小由系统的PIPE_BUF决定,不同操作系统可能不同。

    例子:

    在Linux系统中,终端类似于一个进程,在里面输入:ls | find -name "*.log",这里实际上是创建了两个子进程 ls 和 find,而父进程是终端。

信号:信号是中断机制的一种模拟,在编程实例中,用得比较少,举个例子,在终端上按CTRL + C键表示向当前进程发送一个SIGINT信号,进程终止。

Posix共享内存区实现进程间通信:

共享内存是linux 系统中最底层的通讯机制,也是最快速的通信机制,共享内存区的意思是,同一块物理内存区同时映射到进程A和B的进程地址空间,A可以随时看到B对物理内存区的修改和更新,反之亦然。但是,要解决一个同步和互斥的问题,而信号量和互斥量都可以解决这一问题。

基本上同一计算机内共享区实现进程间通信分不开这4个步骤

1、shmid=shmget(IPC_PRIVATE,SHMDATASIZE,IPC_CREAT|SHM_R|SHM_W);//表示在映射/dev/mem 设备中创建一个2字节大小的共享区域

2、shmdata=shmat(shmid,0,0); /*影射到内存空间*/

3、shmctl(shmid,IPC_RMID,NULL);//对共享区的操作,一般表示使用完之后删除还是其他操作共享区

4、int shmdt (void *addr);//共享区分离进程内存空间地址

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值