linux进程间通信(1)

一、进程通信概述

1、什么是进程间通信?什么是线程间通信?

进程间通信

进程间通信就指的是用户空间中进程A与进程B的通信。

但进程A与进程B在用户空间,相当于封闭的房子,无窗户和门。进程A与进程B在用户空间是不可以进行进程间通信的。

A进程位于用户空间,当执行fork命令调用fork()函数后,就会进入linux内核。linux内核会在用户空间创建另一个进程B。

通过Linux内核空间的对象来通信。
对象不一样,通信方式就不一样。

linux进程间通信(1)_第1张图片
进程间通信

线程间通信:可以在用户空间实现线程间通信,通过全局变量通信。


二、进程间通信方式

1、管道通信

无名管道(文件系统中没有文件名)

有名管道(文件系统中有文件名)

2、信号(通知)通信

信号的发送

信号的接收

信号的处理

3、IPC(Inter-Process Communication)通信

共享内存

消息队列

信号灯

以上6种通信方式是单机模式(只有1个linux内核,即同一个内核)下的进程通信。

4、linux下的网络编程:socket通信

存在于1个网络中2个进程之间的通信(2个linux内核之间)。


三、学习思路

每一种通信方式都是基于文件IO的思想

open:功能:创建或打开进程通信对象。
之间的不同:函数形式不一样,有的是由多个函数完成。
write: 功能:向进程通信对象中写入内容。
之间的不同:函数形式可能不一样。
read: 功能:从进程通信对象中读取内容。
之间的不同:函数形式可能不一样。
close: 功能:关闭或删除进程通信对象。
之间的不同:函数形式可能不一样。

你可能感兴趣的:(linux进程间通信(1))