Linux的历程/线程通讯体例
来源:北大青鸟新途校区|发布时间:2016-05-21|浏览量:
摘要: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号令解析
扫码关注微信公众号了解更多详情
跟技术大咖,专业导师一起交流学习