进程间通信

Posted 盖丽男

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了进程间通信相关的知识,希望对你有一定的参考价值。

什么是进程通信

百度百科:进程通信是指在进程间传输数据(交换信息)。
也就是说,进程通信,就是不同进程之间,来进行的信息交换。
进程间通信(IPC)的一般目的,大概有数据传输、共享数据、通知事件、资源共享和进程控制等。

为什么需要进程通信

那么为什么会需要进程通信的存在呢?
我们知道,操作系统中最核心的概念就是进程,进程是对正在运行中的程序的一个抽象,是系统进行资源分配和调度的基本单位。每个进程都有独立的代码和数据空间,系统在运行的时候会为每个进程分配不同的内存空间
也就是说,在操作系统层面,进程属于最小颗粒,两个进程之间,是没有什么关联性的,是隔离的,当两个进程间需要进行信息交换的时候,就需要用到进程通信。

进程通信的方式

这部分属于操作系统的内容,想详细了解的可以找操作系统的书来看一下
进程通信的方式有七种,分别是:

管道pipe

半双工/单项通信/父子/依赖文件系统

有名管道FIFO

全双工/不需要亲缘关系/命名管道/先进先出

共享内存shared memory

互相通信

消息队列message queue

链表 ,互相通信

信号量semophore

计数器,控制对共享资源的访问,pv操作
保护上面的 共享内存shared memory

信号sinal

异步通信,通知接收进程某个事件已经发生
以下为linux中的信号

套接字socket

不同主机间进行通信用这个,同个主机内的进程也可以用

远程调用

不同主机进程间的通信,就是通过socket,是否还有其他方式,
http应该算一种。

redis的实现

此处提到redis,是因为,redis的客户端和服务端,其实就是通过socket来连接的,可以注意一下。

以上是关于进程间通信的主要内容,如果未能解决你的问题,请参考以下文章

进程间通信和线程间通信

进程间通信

进程间通信方式

进程间,线程间通信方式

8种进程间通信方式

进程间的通信方式