关于锁的几点使用心得

死锁的处理

如果一个操作需要获取多个锁,例如锁A和锁B,那么对多个锁的获取应该始终有固定的先后顺序。例如总是先获取A锁,再获取B锁,否则可能会出现死锁。例如线程1先获取了A锁,线程2先获取了B锁,然后线程1等待获取B锁,线程2等待获取A锁,这样死锁就产生了。

有层次关系的资源的锁处理

如果资源有层级关系,一种简单的方法是只设置一个锁,无论什么操作都获取这个锁。这样正确性是可以保证,只是某些情况下可能并发性不好。于是可以对于不同层次的资源设置不同的锁。假设我们的层次关系如下:

A(锁)--> B(锁) --> C

A(锁)--> D

A资源下有B、D两种资源,其中A和B有自己的锁,其它资源没有自己的锁。我们以读写锁为例说明:

  1. 如果对C进行写操作,那么对A加读锁,对B加写锁。
  2. 如果对C进行读操作,那么对A加读锁,对B加读锁。
  3. 如果对D进行写操作,那么对A加写锁。
  4. 如果对D进行读操作,那么对A加读锁。

D没有自己的锁,所以依赖它上层资源的锁来保护。
C没有自己的锁,所以依赖它上层资源的锁来保护。而B的上层还有资源,所以在修改B下资源的时候,一般不会对B的上层加写锁,而是加读锁,以提高并发度。

异步锁

如果锁的区间非常大,并且需要长时间拿锁,那么可以考虑使用异步锁。即注册回调函数,说明想要获取的锁类型,然后等待回调函数通知。

锁的区间

除了异步锁之外,锁的区间应该尽量地短。因此,不允许在锁内进行内存分配、释放、打印日志等相关的操作。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 拨通电话的时候,姐正在上着班。待我说明意图,她先是推托半天,在我的坚持下,终于应允。 我说:“找时间请咱爸妈...
    沉入海底的鱼阅读 2,790评论 1 1
  • 2017年5月9日 天气小雨 早晨蒙蒙亮,就听到外面稀稀拉拉的下着小雨,老公早早就起床了,为女儿准备好了...
    陌上清歌的简书阅读 1,521评论 0 0
  • 在相同的工作时间里,为什么有的人能够高效出色的完成任务?而有的人却只能勉勉强强地完成工作任务,甚至要加班完成呢?这...
    愚小佳阅读 3,311评论 1 3
  • 轻轻的 摁住了我的胸口 呼吸 却久久不能平静 理想,信仰,希望! 都敌不过腓靡气息 累 囊括我所有心情 在这一刻 ...
    宣丽德阅读 2,669评论 0 8
  • 什么是有钱人? 这是一个别人今天问我的好问题 我觉得这取决于两个维度-----我们自身与身边有钱人的相对差距 和现...
    燕子貓貓阅读 3,064评论 0 0