登录
首页 >  Golang >  Go问答

并行和顺序执行之间的闭包不一致

来源:Golang技术栈

时间:2023-03-22 11:34:10 307浏览 收藏

欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《并行和顺序执行之间的闭包不一致》,这篇文章主要讲到golang等等知识,如果你对Golang相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!

问题内容

我试图编写一个可以并行或顺序执行函数的通用函数。在测试它时,我发现了一些关于闭包的非常意外的行为。在下面的代码中,我定义了一个不接受参数并返回错误的函数列表。这些函数还在闭包中使用 for 循环变量,但我使用在循环中定义新变量的技巧以避免捕获。

我希望我可以按顺序或同时调用这些函数,但效果相同,但我看到了不同的结果。就好像闭包变量被捕获但仅在同时运行时。

据我所知,这不是捕获循环变量的常见情况。正如我所提到的,我在循环中定义了一个新变量。另外,我没有在循环中运行闭包函数。我在循环中生成一个函数列表,但我在循环之后执行函数。

我正在使用 go 版本 go1.8.3 linux/amd64。

package closure_test

import (
    "sync"
    "testing"
)

// MergeErrors merges multiple channels of errors.
// Based on https://blog.golang.org/pipelines.
func MergeErrors(cs ...

下面是上面测试函数的输出。

closure_test.go:91: outer i=0, j=0
closure_test.go:91: outer i=1, j=1
closure_test.go:91: outer i=2, j=2
closure_test.go:91: outer i=3, j=3
closure_test.go:99: Running funcs sequentially
closure_test.go:93: inner i=4, j=0
closure_test.go:93: inner i=4, j=1
closure_test.go:93: inner i=4, j=2
closure_test.go:93: inner i=4, j=3
closure_test.go:104: Running funcs in parallel
closure_test.go:93: inner i=4, j=3
closure_test.go:93: inner i=4, j=3
closure_test.go:93: inner i=4, j=3
closure_test.go:93: inner i=4, j=3
closure_test.go:80: Output channel has 1 unique items; wanted 4

有任何想法吗?这是 Go 中的错误吗?

正确答案

始终使用 -race 运行测试。f在您的情况下,您忘记在每次迭代中重新创建RunInParallel

func RunInParallel(funcs ...func() error) error {
    var errcList [](

结果,您总是启动最后一个f而不是每个。

终于介绍完啦!小伙伴们,这篇关于《并行和顺序执行之间的闭包不一致》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

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