登录
首页 >  Golang >  Go问答

mutex.Lock() 如何知道要锁定哪些变量?

来源:stackoverflow

时间:2024-04-23 15:00:37 154浏览 收藏

Golang小白一枚,正在不断学习积累知识,现将学习到的知识记录一下,也是将我的所得分享给大家!而今天这篇文章《mutex.Lock() 如何知道要锁定哪些变量?》带大家来了解一下##content_title##,希望对大家的知识积累有所帮助,从而弥补自己的不足,助力实战开发!


问题内容

我是个新手,所以请温柔一点。

所以我已经在我的一些代码中使用互斥体几周了。我理解其背后的概念:锁定对特定资源的访问,与其交互(读或写),然后再次为其他资源解锁。

我使用的互斥体代码主要是复制粘贴调整。代码运行了,但我仍在尝试了解它的内部工作原理。到目前为止,我一直在结构中使用互斥体来锁定结构。今天我发现了这个例子,这让我完全不清楚互斥锁实际上锁定了什么。下面是一段示例代码:

var state = make(map[int]int)

var mutex = &sync.Mutex{}

var readOps uint64
var writeOps uint64

// Here we start 100 goroutines to execute repeated reads against the state, once per millisecond in each goroutine.
for r := 0; r < 100; r++ {
    go func() {
        total := 0
        for {
            key := rand.Intn(5)
            mutex.Lock()
            total += state[key]
            mutex.Unlock()
            atomic.AddUint64(&readOps, 1)

            time.Sleep(time.Millisecond)
        }
    }()
}

令我困惑的是,互斥体和它应该锁定的值之间似乎没有任何联系。直到今天,我还认为互斥锁可以锁定特定变量,但查看这段代码,似乎以某种方式锁定整个程序,只执行锁定下方的行,直到再次运行解锁。我想这意味着所有其他 goroutine 都会暂停一会儿,直到再次运行解锁。由于代码已编译,我想它可以知道 lock()unlock() 之间访问哪些变量,但我不确定是否是这种情况。

如果所有其他程序暂停一会儿,这听起来不像真正的多处理,所以我猜我对发生的事情没有很好的理解。

有人可以帮我理解计算机如何知道应该锁定哪些变量吗?


解决方案


锁定对特定资源的访问,与其交互(读或写),然后再次为其他资源解锁。

基本上是的。

让我困惑的是,互斥体和它应该锁定的值之间似乎没有任何联系。

互斥体只是一个互斥对象,用于同步对资源的访问。这意味着,如果两个不同的 goroutine 想要锁定互斥锁,则只有第一个 goroutine 可以访问它。第二个 goroutine 现在无限期地等待,直到它自己可以锁定互斥锁。与变量没有任何联系,您可以根据需要使用互斥体。例如只有一个http请求,只有一个数据库读/写操作或者只有一个变量赋值。虽然我不建议在这些示例中使用互斥锁,但总体思路应该会变得清晰。

但是看看这段代码,它似乎以某种方式锁定了整个程序,只执行锁定下方的行,直到再次运行解锁。

不是整个程序,只有每个想要访问相同互斥体的 goroutine 才会等待,直到它可以访问为止。

我想这意味着所有其他 goroutine 都会暂停一会儿,直到再次运行解锁。

不,他们不会暂停。它们执行直到想要访问相同的互斥锁为止。

如果您想使用变量专门对互斥体进行分组,为什么不创建一个结构体?

理论要掌握,实操不能落!以上关于《mutex.Lock() 如何知道要锁定哪些变量?》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>