这篇文章主要介绍了Go语言中的sync.Mutex如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Go语言中的sync.Mutex如何使用文章都会有所收获,下面我们一起来看看吧。
多个协程操作中经常出现脏读写的情况,这种情况下需要使用互斥锁,保证在对协程共享区域操作的原子性。
如下示例:
启动了 100个协程,每个协程累加 100 次,在没有脏读写的情况下,最后结果应该是 100 * 100 = 10000
package main
import (
"fmt"
"sync"
)
func main() {
var count = 0
var wg sync.WaitGroup
wg.Add(100)
for i :=0; i< 100; i++ {
go func(){
defer wg.Done()
for j := 0; j< 100; j ++ {
count ++
}
}()
}
wg.Wait()
fmt.Println(count)
}
但是实际结果一直小于 10000
count ++ 操作, 分为三个步骤
在协程的共享区域取出 count 当前值
当前值加一
加一后的值写回协程共享区域
这时需要使用互斥锁, 来保证对 count++ 的三个操作过程中没有其他协程进行读写。
Go的Sync 包提供了Mutex, 读写互斥的锁, 来保证只有一个协程对数据进行读写操作。 以保证 count++操作的原子性
如下示例:
package main
import (
"fmt"
"sync"
)
func main() {
var count = 0
// 声明Mutex变量
var mu sync.Mutex
var wg sync.WaitGroup
wg.Add(100)
for i :=0; i< 100; i++ {
go func(){
defer wg.Done()
for j := 0; j< 100; j ++ {
// 添加锁
mu.Lock()
count ++
// 解锁
mu.Unlock()
}
}()
}
wg.Wait()
fmt.Println(count)
}
在mu.Lock()
和mu.Unlock()
之间的代码可以保证在操作只会被一个协程执行。这样执行结果就是 10000 了
mu.Lock()
和mu.Unlock()
必须成对出现,在忘掉 Unlock 的情况下,锁获取后永远不会得到释放,其他 的线程/协程会永远处于阻塞状态,永远获取不到锁,在忘掉 Lock 的情况下,直接 Unlock 一个未加锁的 Mutex,会导致程序 panic。
关于“Go语言中的sync.Mutex如何使用”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“Go语言中的sync.Mutex如何使用”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注亿速云行业资讯频道。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://blog.csdn.net/qq_21047625/article/details/129208966