Linux内核中的同步

本文探讨了Linux内核中的同步问题,包括并发产生的原因、死锁及其避免方法、原子操作、自旋锁、信号量、互斥体、完成量以及大内核锁等关键概念。强调了自旋锁适用于短期轻量级加锁,信号量适合长时间持有,互斥体用于复杂互斥访问,并介绍了如何避免死锁和选择合适的同步机制。
摘要由CSDN通过智能技术生成

版权所有,转载请说明转自 http://my.csdn.net/weiqing1981127

 

如果一个进程正处于临界区时被非自愿抢占了,而且这个新调度的进程随后也进入同一个临界区,前后两个进程之间就会产生竞争,其实两者并不真是同时发生的,但它们相互交叉进行,所以叫做伪并发。如果有一台支持对称多处理器(SMP)的机器,那么两个进程就可以真正地在临界区中同时执行,这就叫真并发。

并发产生的原因有:第一,中断;第二,软中断和tasklet;第三,内核抢占;第四,睡眠及与用户空间的同步;第五,对称多处理。

 

设计锁在开始阶段都很粗,但当锁的争用问题变得严重时,设计就向更加细的加锁方向发展。那么什么样的数据需要加锁呢?其一,如果有其他执行线程可以访问这些数据,那么就给这些数据加上某种形式的锁;。其二,如果任何其他什么东西都能看到它,那么就要锁住它。其三,几乎访问所有的内核全局变量和共享数据都需要某种形式的同步方法。

 

每个线程都在等待其中的一个资源,但所有的资源都已经被占用了,所有线程都在相互等待,但它们永远不会释放已经占有的资源&

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值