进程间通信

简介: 进程间通信

什么是进程通信

百度百科:进程通信是指在进程间传输数据(交换信息)。

也就是说,进程通信,就是不同进程之间,来进行的信息交换。

进程间通信(IPC)的一般目的,大概有数据传输、共享数据、通知事件、资源共享和进程控制等。

为什么需要进程通信

那么为什么会需要进程通信的存在呢?

我们知道,操作系统中最核心的概念就是进程,进程是对正在运行中的程序的一个抽象,是系统进行资源分配和调度的基本单位。每个进程都有独立的代码和数据空间,系统在运行的时候会为每个进程分配不同的内存空间

也就是说,在操作系统层面,进程属于最小颗粒,两个进程之间,是没有什么关联性的,是隔离的,当两个进程间需要进行信息交换的时候,就需要用到进程通信。

进程通信的方式

这部分属于操作系统的内容,想详细了解的可以找操作系统的书来看一下

进程通信的方式有七种,分别是:

管道pipe

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

有名管道FIFO

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

共享内存shared memory

互相通信

消息队列message queue

链表 ,互相通信

信号量semophore

计数器,控制对共享资源的访问,pv操作

保护上面的 共享内存shared memory

信号sinal

异步通信,通知接收进程某个事件已经发生

以下为linux中的信号

套接字socket

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

远程调用

不同主机进程间的通信,就是通过socket,是否还有其他方式,

http应该算一种。

redis的实现

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

目录
相关文章
|
12月前
|
存储 并行计算 算法
C++进程间通信之共享内存
C++进程间通信之共享内存
731 0
|
4月前
|
消息中间件 负载均衡 安全
进程间通信
数据传输:一个进程需要将它的数据发送给另一个进程资源共享:多个进程之间共享同样的资源。通知事件:一个进程需要向另一个或一组进程发送消息,通知它(它们)发生了某种事件(如进程终止时要通知父进程)。进程控制:有些进程希望完全控制另一个进程的执行(如Debug进程),此时控制进程希望能够拦截另一个进程的所有陷入和异常,并能够及时知道它的状态改变。进程间通信的本质:让不同的进程先看到同一份资源,但是这份资源不能由双方进程提供,而通常是由操作系统所提供!
37 9
进程间通信
|
API
IPC(进程间通信)(下)
IPC(进程间通信)(下)
50 0
|
Unix
进程间通信(一)
进程间通信
66 0
|
消息中间件
进程间通信(非常实用)
进程间通信(非常实用)
|
Linux
2.10~2.29 进程间通信(下)
2.10~2.29 进程间通信
107 0
2.10~2.29 进程间通信(下)
|
Linux
2.10~2.29 进程间通信(上)
2.10~2.29 进程间通信
88 0
2.10~2.29 进程间通信(上)
|
开发者
进程间通信 | 学习笔记
快速学习进程间通信,介绍了进程间通信系统机制, 以及在实际应用过程中如何使用。
进程间通信——共享内存
进程间通信——共享内存
212 0
进程间通信——共享内存