一、进程通信概述
1、什么是进程间通信?什么是线程间通信?
进程间通信:
进程间通信就指的是用户空间中进程A与进程B的通信。
但进程A与进程B在用户空间,相当于封闭的房子,无窗户和门。进程A与进程B在用户空间是不可以进行进程间通信的。
A进程位于用户空间,当执行fork命令调用fork()函数后,就会进入linux内核。linux内核会在用户空间创建另一个进程B。
通过Linux内核空间的对象来通信。
对象不一样,通信方式就不一样。
线程间通信:可以在用户空间实现线程间通信,通过全局变量通信。
二、进程间通信方式
1、管道通信
无名管道(文件系统中没有文件名)
有名管道(文件系统中有文件名)
2、信号(通知)通信
信号的发送
信号的接收
信号的处理
3、IPC(Inter-Process Communication)通信
共享内存
消息队列
信号灯
以上6种通信方式是单机模式(只有1个linux内核,即同一个内核)下的进程通信。
4、linux下的网络编程:socket通信
存在于1个网络中2个进程之间的通信(2个linux内核之间)。
三、学习思路
每一种通信方式都是基于文件IO的思想。
open
:功能:创建或打开进程通信对象。
之间的不同:函数形式不一样,有的是由多个函数完成。
write
: 功能:向进程通信对象中写入内容。
之间的不同:函数形式可能不一样。
read
: 功能:从进程通信对象中读取内容。
之间的不同:函数形式可能不一样。
close
: 功能:关闭或删除进程通信对象。
之间的不同:函数形式可能不一样。
网友评论