麓谷官网欢迎你访问长沙北大青鸟麓谷校区,支持你成为一个受人尊重的专业人才!
当前位置: 首页 > 青鸟知识 > 网络技术

Linux的历程/线程通讯体例

来源:北大青鸟新途校区|发布时间:2016-05-21|浏览量:

学IT,好工作

就读长沙岳麓职业培训学校

求学热线: 400-160-2868
摘要:Linux的进程/线程通讯格式 ,* UNIX进程间通讯格式: 包罗管道(PIPE), 着名管道(FIFO), 和旌旗灯号(Signal)

Linux系统中的进程通讯格式首要以下几种:

统一主机上的进程通讯格式

  * UNIX进程间通讯格式: 包罗管道(PIPE), 着名管道(FIFO), 和旌旗灯号(Signal)

  * System V进程通讯格式:包罗旌旗灯号量(Semaphore), 动静队列(Message Queue), 和同享内存(Shared Memory)

搜集主机间的进程通讯格式

  * RPC: Remote Procedure Call 长途进程挪用

  * Socket: 以后最流行的搜集通讯格式, 基于TCP/IP和谈的通讯格式.

各自的特性:

管道(PIPE):管道是一种半双工的通讯格式,数据只能单向活动,并且只能在具有亲缘关系(父子进程)的进程间应用。别的管道传送的是无格局的字俭省,而且管道缓冲区的年夜小是无限的(管道缓冲区存在于内存中,在管道树立时,为缓冲区分配一个页面年夜小)。

着名管道 (FIFO): 着名管道也是半双工的通讯格式,可是它答应无亲缘关系进程间的通讯。

旌旗灯号(Signal): 旌旗灯号是一种比力复杂的通讯格式,用于通知领受进程某个事务已产生。

旌旗灯号量(Semaphore):旌旗灯号量是一个计数器,能够用来节制多个进程对同享资本的拜候。它常作为一种锁机制,防止某进程正在拜候同享资本时,其他进程也拜候该资本。是以,首要作为进程间和统一进程内分歧线程之间的同步伎俩。

动静队列(Message Queue):动静队列是由动静的链表,存放在内核中并由动静队列标识符标识。动静队列降服了旌旗灯号传送信息少、管道只能承载无格局字俭省弛缓冲区年夜小受限等错误错误。

同享内存(Shared Memory ):同享内存就是映照一段能被其他进程所拜候的内存,这段同享内存由一个进程树立,但多个进程都能够拜候。同享内存是最快的 IPC 格式,它是针对其他进程间通讯格式运转效能低而特地想象的。它常常与其他通讯机制,如旌旗灯号量,共同应用,来完成进程间的同步和通讯。

套接字(Socket): 套解口也是一种进程间通讯机制,与其他通讯机制分歧的是,它可用于分歧主机间的进程通讯。

Linux系统中的线程通讯格式首要以下几种:

*  锁机制:包罗互斥锁、前提变量、读写锁

  互斥锁供应了以排他格式防止数据规划被并发点窜的方式。

  应用前提变量能够以原子的格式梗阻进程,直到某个特定前提为真为止。对前提的测试是在互斥锁的庇护下中止的。前提变量不断与互斥锁一路应用。

  读写锁答应多个线程同时读同享数据,而对写支配是互斥的。

*  旌旗灯号量机制(Semaphore):包罗无名线程旌旗灯号量和定名线程旌旗灯号量

*  旌旗灯号机制(Signal):近似进程间的旌旗灯号处置

线程间的通讯目的首要是用于线程同步。所以线程没有像进程通讯中的用于数据互换的通讯机制。

上一篇:Linux线程同步之前提变量

下一篇:Linux ln号令解析

扫码关注微信公众号了解更多详情

跟技术大咖,专业导师一起交流学习

姓名
电话
Q Q

在线留言

请您把问题留下,我们为您提供专业化的解答!

QQ咨询
  1. 招生问答
  2. 热门点击
  3. 最新更新
  4. 推荐文章

关于我们

学校成就

就业保障

联系方式

联系电话:400-160-2868

在线报名

预约报名

备案号:湘ICP备2020021619号-1
地址:湖南省长沙市高新区麓谷麓松路679号 版权所有:长沙市岳麓职业培训学校

在线咨询
课程咨询 学费咨询 学费分期 入学测试 免费预约 来校路线
初中生 高中生 待业者
400-160-2868

在线客服