美文网首页Linux
linux进程间通信(1)

linux进程间通信(1)

作者: 3e1094b2ef7b | 来源:发表于2017-04-27 16:11 被阅读23次

一、进程通信概述

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: 功能:关闭或删除进程通信对象。
之间的不同:函数形式可能不一样。

相关文章

  • 进程间的通信

    进程间的通信主要分为本机器进程间的通信和不同机器间进程的通信。本文主要描述本机进程间的通信。 一、传统Linux的...

  • linux进程间通信(1)

    一、进程通信概述 1、什么是进程间通信?什么是线程间通信? 进程间通信: 进程间通信就指的是用户空间中进程A与进程...

  • 共享内存

    Linux进程间通信 - 共享内存

  • Linux进程间通信

    Linux进程间通信的概念 linux下进程间通信的几种主要手段简介: 管道(Pipe)及有名管道(named p...

  • Linux进程基础行为(二)

    本节主要讲Linux进程间通信在Linux中,各个进程都共享内核空间,因此LInux进程通信中的管道,消息队列等都...

  • 进程间通信方式

    01概述 1.1 发展 Linux进程间通信(IPC)大致发展如下: 早期UNIX进程间通信、基于System ...

  • Android跨进程通信IPC系列

    Android跨进程通信IPC之1——Linux基础Android跨进程通信IPC之2——Linux的跨进程通信详...

  • Linux 下传统的进程间通信原理

    Linux 下传统的进程间通信原理 在Linux中跨进程通信涉及到几个基本的概念 进程间隔离 进程空间划分:用户空...

  • 零散的小知识记录(待补充和修改)

    Android跨进程通信:Binder,socket/管道/消息队列,共享内存; linux进程间通信:管道,Bi...

  • 进程间的通信

    进程间的通信方式(IPC)有哪些,各有什么优缺点? Linux内核解析:进程间通信:管道 - 笨拙的菜鸟 - 博客...

网友评论

    本文标题:linux进程间通信(1)

    本文链接:https://www.haomeiwen.com/subject/jpldgttx.html