操作系统—线程同步机制

一、前沿

在进程/线程并发执行的时候,进程/线程之间存在协作的关系,即互斥或同步。接下来这篇主要讲述,线程的同步机制 

同步概念:所谓同步,就是并发进程/线程在一些关键点上可能需要互相等待与互通消息,这种相互制约的等待与互通信息称为进程/线程同步。

二、线程同步机制

(1)互斥量:互斥对象只有⼀个,可以保证公共资源不被多个线程访问

(2)信号量:整型变量,允许多个线程同⼀时刻访问同⼀资源,但是需要限制访问的线程数目 

(3)临界区:对临界资源进⾏访问的那段程序代码;多个线程访问⼀个独占性共享资源,拥有 临界区的对象被保护起来,其他想访问临界区的线程被挂起

(4)事件/信号:通知/唤醒线程有时间发生

(5)屏障:用户协调多个线程并行工作的同步机制。屏障允许每个线程等待,直到所有的合作线程都到达某一点,然后所有线程都从该点继续执行。

其实,还有锁机制也能实现线程同步,比如读写锁、互斥锁、自旋锁等,本文主要针对以上五种线程同步机制进行叙述hh,见谅啦

三、五种线程同步机制区别

优点缺点
临界区保证某⼀时刻只有⼀个线程访问 的简便⽅法,速度快只能⽤来同步本进程内的线程
互斥量可以在不同进程的线程之间实现 资源的安全共享;和临界区很相似,但是互斥量是可以命名的创建耗费资源更多
信号量适⽤于Socket程序中的同步必须有公共内存,不适合分布式操作 系统,不易管理可控制、易出错
事件/信号可以实现不同进程中线程的同步
屏障实现多个线程并行工作的同步需要等到所有线程完成工作

其实,线程同步就是相互制约的等待与互通信息。这其中就涉及到进程/线程间通信,锁、信号量、信号都可以用于线程间的同步。

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱吃代码的航航

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值