互斥锁在 go 中的阻塞问题
在这个代码中,虽然外部锁定了变量,但内部锁仍然可以正常使用。这是因为外部锁仅影响同一协程内的锁操作。
代码示例:
package mainimport ( "fmt" "sync" "time")func main() { var mutex sync.mutex wait := sync.waitgroup{} fmt.println("locked") mutex.lock() // 外部锁 for i := 1; i <= 3; i++ { wait.add(1) go func(i int) { fmt.println("not lock:", i) mutex.lock() // 内部锁 fmt.println("lock:", i) time.sleep(time.second) fmt.println("unlock:", i) mutex.unlock() defer wait.done() }(i) } time.sleep(time.second) fmt.println("unlocked") mutex.unlock() // 外部锁解锁 wait.wait()}
登录后复制
输出:
LockedNot lock: 1Not lock: 2Not lock: 3UnlockedLock: 1Unlock: 1Lock: 2Unlock: 2Lock: 3Unlock: 3
登录后复制
解释:
在输出中,我们可以看到:
外部锁(mutex.lock())在 “locked” 后立即被加锁。三个协程在 “not lock: n” 后执行代码,说明此时外部锁并未影响内部锁。随后,外部锁(mutex.unlock())在 “unlocked” 后被解锁,这也是外部锁对内部锁的影响结束的时刻。三个协程随后在 “lock: n” 后被依次加锁,说明内部锁在外部锁解锁后才生效。
因此,我们可以得出结论:
在 go 中,不同的协程中的互斥锁是独立的。外部锁只会影响同一协程中的内部锁操作。
以上就是Go 语言中的互斥锁:外部锁如何影响内部锁?的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2311430.html