GO的Mutex(互斥锁)和RWMutex(读写锁)
admin
2024-05-08 15:50:45
0

GO的Mutex(互斥锁)和RWMutex(读写锁)

文章目录

  • GO的Mutex(互斥锁)和RWMutex(读写锁)
    • 一、竞态条件、临界区、同步工具
      • (1)竞态条件
      • (2)临界区
      • (3)同步工具
    • 二、互斥量(mutual exclusion,简称mutex)
    • 三、使用互斥锁的注意事项
      • (1)使用互斥锁的注意事项
      • (2)最保险的做法:使用defer 语句解锁
      • (3)`sync.Mutex`是值类型
    • 四、读写锁与互斥锁的异同
      • (1)读/写互斥锁
      • (2)读写锁规则
      • (3)解锁读写锁

一、竞态条件、临界区、同步工具

(1)竞态条件

一旦数据被多个线程共享,那么就会产生冲突和争用的情况,这种情况被称为竞态条件。这往往会破坏数据的一致性。

同步的用途有两个,一个是避免多线程在同一时刻操作同一个数据块,另一个是协调多线程,以避免它们在同一时刻执行同一个代码块。

(2)临界区

一个线程在想要访问某一个共享资源的时候,需要先申请对该资源的访问权限,并且只有在申请成功之后,访问才能真正开始。

而当线程对共享资源的访问结束时,它还必须归还对该资源的访问权限,若要再次访问仍需申请。

我们可以说,多个并发运行的线程对这个共享资源的访问是完全串行的,只要一个代码片段需要实现对共享资源的串行化访问,就可以被视为一个临界区。由于要访问到资源而必须进入到那个区域。

(3)同步工具

临界区总是受保护的,否则会产生竞态条件。施加保护的重要手段之一,就是使用实现了某种同步机制的工具,也称为同步工具。

二、互斥量(mutual exclusion,简称mutex)

在Go语言中,可供我们选择的同步工具不少。其中,最重要且最常用的同步工具当属互斥量(mutual exclusion,简称mutex)。

sync包中的Mutex就是与其对应的类型,该类型的值可以被称为互斥量或者互斥锁。

一个互斥锁可以被用来保护一个临界区或者一组临界区。我们可以通过它来保证,在同一时刻只有一个goroutine处于该临界区。

为了实现这个保证,每当有goroutine想进入临界区,都要先对它进行锁定,并且,每个goroutine离开临界区,都要及时对它进行解锁。

  • 锁定操作:调用互斥锁的Lock方法;
  • 解锁操作:调用互斥锁的Unlock方法;
mu.Lock()
_, err := writer.Write([]byte(data))
if err != nil {log.Printf("error: %s [%d]", err, id)
}
mu.Unlock()

go run demo01.go -protecting=0

三、使用互斥锁的注意事项

(1)使用互斥锁的注意事项

使用互斥锁的注意事项如下:

  1. 不要重复锁定互斥锁;
  2. 不要忘记解锁互斥锁,必要时使用defer语句;
  3. 不要对尚未锁定或已解锁的互斥锁解锁;
  4. 不要在多个函数之间传递互斥锁;

把一个互斥锁同时用在多个地方,不但会让程序变慢,还会大大增加死锁的可能性。

有GO语言运行时系统自行抛出的panic都属于致命错误,都是无法被恢复的,调用recover函数对他们起不到任何作用。也就是说,一旦产生死锁,程序必然崩溃。

为了避免这种情况,最简单有效的方法就是让每一个互斥锁都只保护一个临界区或一组相关临界区。在这个前提下,还要注意,就不要重复锁定一个互斥锁,也不要忘记对它的解锁。

一个goroutine对某一个互斥锁重复锁定,就意味着它自己锁死自己。

不要忘记解锁的一个重要原因是:避免重复锁定

同样,解锁未锁定的互斥锁会立即引发 panic。

(2)最保险的做法:使用defer 语句解锁

如果一个流程在锁定了某个互斥锁之后分叉了,或者有被中断的可能,那么就应该使用defer语句来对它进行解锁,而且这样的defer语句应该紧跟在锁定操作之后。这是最保险的一种做法。

(3)sync.Mutex是值类型

Go 语言中的互斥锁是开箱即用的。换句话说,一旦我们声明了一个sync.Mutex类型的变量,就可以直接使用它了。

不过要注意,该类型是一个结构体类型,属于值类型中的一种。把它传给一个函数、将它从函数中返回、把它赋给其他变量、让它进入某个通道都会导致它的副本的产生。

并且,原值和它的副本,以及多个副本之间都是完全独立的,它们都是不同的互斥锁。

四、读写锁与互斥锁的异同

(1)读/写互斥锁

读写锁是读/写互斥锁的简称。在Go语言中,读写锁由sync.RWMutex类型的值代表。与sync.Mutex类型一样,也是开箱即用。

一个读写锁中,实际包含两个锁,即:读锁和写锁。

sync.RWMutex类型中的Lock方法和Unlock方法分别用于对写锁进行锁定和解锁,而它的RLock方法和RUnlock方法则分别用于对读锁进行锁定和解锁。

(2)读写锁规则

  1. 在写锁已被锁定的情况下再试图锁定写锁,会阻塞当前的 goroutine。
  2. 在写锁已被锁定的情况下试图锁定读锁,也会阻塞当前的 goroutine。
  3. 在读锁已被锁定的情况下试图锁定写锁,同样会阻塞当前的 goroutine。
  4. 在读锁已被锁定的情况下再试图锁定读锁,并不会阻塞当前的 goroutine。

多个写操作不能同时进行,写操作和读操作也不能同时进行,但多个读操作却可以同时进行。

(3)解锁读写锁

对写锁进行解锁,会唤醒“所有因试图锁定读锁,而被阻塞的 goroutine”,并且,这通常会使它们都成功完成对读锁的锁定。

对读锁进行解锁,只会在没有其他读锁锁定的前提下,唤醒“因试图锁定写锁,而被阻塞的 goroutine”;并且,最终只会有一个被唤醒的 goroutine 能够成功完成对写锁的锁定,其他的 goroutine 还要在原处继续等待。至于是哪一个 goroutine,那就要看谁的等待时间最长了。

与互斥锁类似,解锁“读写锁中未被锁定的写锁”,会立即引发 panic,对于其中的读锁也是如此,并且同样是不可恢复的。,与互斥锁类似,解锁“读写锁中未被锁定的写锁”,会立即引发 panic,对于其中的读锁也是如此,并且同样是不可恢复的。

相关内容

热门资讯

皇子归来之欢喜知府和皇子归来之... 皇子归来之欢喜知府和皇子归来之欢喜县令是一部戏吗我个人觉得是,只是属于不同的章节
古人为何远比现代人重视后世史书... 古人为何远比现代人重视后世史书对自己的评价?其实现代人也比较重视史书,因为人更爱追求长生之道,如果不...
我放学后做作业英文怎么写? 我放学后做作业英文怎么写?I do homework after shool.I do my ho...
请是学者的看过来,帮看看我还有... 请是学者的看过来,帮看看我还有可能成为一名学者吗虽然我不是学者,我还是想说:既然已经做了,也坚持了,...
这是犬夜叉里的第几集? 这是犬夜叉里的第几集?是犬夜叉第65集:再见了,青春的每一天。冥加爷爷的未婚妻日向奶奶跳到犬夜叉身上...
谁能帮我把这个网页中的文字提取... 谁能帮我把这个网页中的文字提取出来啊,感激不尽!你在浏览器上 点击 查看--源文件 就可以看到了
怎么做小学生剪贴报 怎么做小学生剪贴报 急要,求求各位 网上下点图片小学生嘛排版好看点就行了材料可以叫大人删改一下
博学审问慎,思明辩笃行的意思是... 博学审问慎,思明辩笃行的意思是?想问博学审问慎,思明辩笃行的意思博学虽未能审问慎思明辩笃行期与诸君共...
小孩没娘是什么 小孩没娘是什么如果有人跟你说:“这孩子没娘” 你就会问:“为什么呢?” 接着他就会说:“因为他娘死的...
极品飞车9和10的故事 极品飞车9和10的故事请帮我详细介绍一下。不过它们到底有什么瓜葛?... 请帮我详细介绍一下。不过...
多媒体技术应用领域的介绍 多媒体技术应用领域的介绍 多媒体技术应用领域集文字、声音、图像、视频、通信等多项技术于一体,采用计算...
影视剧里有哪些巧妙的广告植入? 影视剧里有哪些巧妙的广告植入?现在不就网剧喜欢植入广告,不过还挺好看。
一分钟漫画物理和我的第一本物理... 一分钟漫画物理和我的第一本物理启蒙书哪个好我的第一本物理启蒙书好。这套书用一个个有趣的绘本故事让孩子...
阴阳师手游书翁传记怎么解锁 书... 阴阳师手游书翁传记怎么解锁 书翁传记解锁方法介绍阴阳师书翁传记解锁攻略:传记一解锁条件:通关御魂第十...
紧张工作和享受生活,有矛盾吗? 紧张工作和享受生活,有矛盾吗?这两者之间当然不矛盾,该工作的时候应该要认真工作,但是如果生活中只有工...
爱永久的存在吗? [ 爱永久的存在吗? [天长地久的爱情就在你心中,就象很多人经常问这个世界上到底有没有真爱一样,其实真爱...
杨袁取什么名字好听 杨袁取什么名字好听请问是姓杨然后袁字辈的吗?还是分别为杨姓和袁姓取名字呢?好,我直接都帮你推荐几个吧...
《千山暮雪》中刘恺威演唱的《千... 《千山暮雪》中刘恺威演唱的《千山》求无毒高品质完整版~已发送 注意查收!
想成为编程高手,都要学习什么知... 想成为编程高手,都要学习什么知识?多看看书,多实践,多思考,多求变
读不完的大书是童话故事吗 读不完的大书是童话故事吗  《读不完的大书》不是童话故事,是朱维之先生写的一篇散文。文章通过对野外与...