登录
首页 >  Golang >  Go问答

Go 书籍示例代码中的并发结果难以复现

来源:stackoverflow

时间:2024-02-18 12:48:23 461浏览 收藏

一分耕耘,一分收获!既然打开了这篇文章《Go 书籍示例代码中的并发结果难以复现》,就坚持看下去吧!文中内容包含等等知识点...希望你能在阅读本文后,能真真实实学到知识或者帮你解决心中的疑惑,也欢迎大佬或者新人朋友们多留言评论,多给建议!谢谢!

问题内容

我正在阅读 katherine cox-buday 撰写的《go 中的并发:开发人员工具和技术》。到目前为止读得很好,我偶然发现了书中我想测试的一段代码。当我在 ide 中运行它时,我得到了不同的结果,但我不知道为什么。 这是代码:

package main

import (
"fmt"
"sync"
)

func main() {
var count int
var lock sync.mutex
increment := func() {
    lock.lock()
    defer lock.unlock()
    count++
    fmt.printf("incrementing: %d\n", count)
}
decrement := func() {
    lock.lock()
    defer lock.unlock()
    count--
    fmt.printf("decrementing: %d\n", count)
}
// increment
var arithmetic sync.waitgroup
for i := 0; i <= 5; i++ {
    arithmetic.add(1)
    go func() {
        defer arithmetic.done()
        increment()
    }()
}
// decrement
for i := 0; i <= 5; i++ {
    arithmetic.add(1)
    go func() {
        defer arithmetic.done()
        decrement()
    }()
}
arithmetic.wait()
fmt.println("arithmetic complete.")
}

我得到这个结果:

$ go run main.go
incrementing: 1
incrementing: 2
incrementing: 3
incrementing: 4
incrementing: 5
incrementing: 6
decrementing: 5
decrementing: 4
decrementing: 3
decrementing: 2
decrementing: 1
decrementing: 0
arithmetic complete.

而在书中我应该得到这样的结果:

Decrementing: -1
Incrementing: 0
Decrementing: -1
Incrementing: 0
Decrementing: -1
Decrementing: -2
Decrementing: -3
Incrementing: -2
Decrementing: -3
Incrementing: -2
Incrementing: -1
Incrementing: 0
Arithmetic complete.

有人可以帮我解释一下吗?


解决方案


无法保证 goroutine 的运行顺序。根据运行时如何调度它们,当您多次运行程序时,goroutine 可以按不同的顺序运行。您观察到的输出似乎是 goroutine 的有效交错之一,而本书仅列出了可能的输出之一。

终于介绍完啦!小伙伴们,这篇关于《Go 书籍示例代码中的并发结果难以复现》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

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