进程间通信

概念:

        进程间通信其实就是多个进程之间进行数据交互

问题:

        进程间为什么不能直接进行数据交互,需要使用系统提供的方式?

解答:

        进程之间具有独立性,每个进程都有自己的虚拟空间,访问数据的时候都是通过自己的虚拟地址进行访问的,一个进程将自己的某个变量的空间地址(虚拟地址)交给另一个进程,另一个进程是无法访问的。

        操作系统提供进程间通信方式,其实就是给多个进程之间提供一个空间的交叉点,让多个进程都可以访问到,才能形成通信。

操作系统根据不同场景,提供不同的通信方式:

        管道:适用于数据传输的场景

        共享内存:适用于数据共享的场景

        消息队列:适用于数据传输的场景

        信号量:使用进程的协同控制(实现进程间的同步与互斥)

管道:

        管道的特性:

                半双工通信

                本质上,在我们程序中,管道其实是内核中的一块缓冲区(其实就是一块内存)

                多个进程通过访问同一块缓冲区来实现数据传输

                管道的本质是内核中的一块缓冲区,但是linux操作系统中,一切皆文件,将管道当作                文件来处理

        管道的分类:

                匿名管道:

                        没有名字(标识符)管道,无法被其他进程找到

                        特性:

                                只能用于具有亲缘关系的进程间通信

                命名管道:

                        有名字(标识符)管道,可以被其他进程找到

                        特性:

                                可以用于同一主机上的任意进程间通信

                管道原理:

                        进程通过系统调用接口创建完管道后,这个系统调用接口就给进程返回了一                            个管道的操作句柄(相当于遥控器),而匿名管道没有标识符,无法被其他进程找到,                  所以无法进行通信,这时候,只能通过创建子进程的方式进程子进程复制了父进程,也                  就复制了父进程所拥有的操作句柄,通过这个句柄可以访问到这个管道

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值