读书笔记之linux/unix系统编程手册(43)

进程间通信介绍
1.unix系统上各种通信和同步工具,并根据功能将他们分成了三类
(1)通信:这些工具关注进程之间的数据交换
(2)同步: 这些进程关注进程和线程操作之间的同步
(3)信号:尽管信号的主要作用并不在此,但在特定场景下可以将它作为一种同步技术
2.数据传输工具:为了通信,一个进程将数据写入IPC工具,另一个从中读取数据。这些工具要求在用户内存和内核内存之间进行两次数据传输:一次传输时写入时从用户内存到内核内存,另一次传输是在读取时候从内核内存到用户内存
3.共享内存:共享内存允许进程通过将数据放到有进程间共享的一块内存中以完成信息的交换。
4.数据传输分为两大类:字节流(管道,fifo,数据包socket),消息(两种消息队列以及数据报socket)
5.共享内存:信号量用来作为同步的方法
6.信号量:一个信号量是一个内核维护的整数,其值永远不会小于0.一个进程可以增加或减小一个信号量的值。如果一个进程试图将信号量的值减小到小于0,那么内核会阻塞该操作直至信号量的增长到允许执行该操作的程度(或者非阻塞,直接返回错误)。一个进程减小一个信号量是为了预约对共享资源的独占访问,在完成了使用之后可以增加信号量。二元信号量使用较多,但处理一类共享资源拥有多个实例的应用程序需要使用最大值等于共享资源数量的信号量
7.文件锁:文件锁是设计用来协调操作同一个文件的多个进程的动作的一种同步方法。文件锁分为读锁和写锁。
8.互斥体和条件变量:这些同步工具通常用于posix线程
9.IPC持久性:只有当当显示的删除IPC对象或系统关闭,该对象才会被销毁,否则该对象会一直存在

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值