【发布时间】:2013-12-17 06:12:24
【问题描述】:
Go : 缓冲通道总和更快?
在以下游乐场链接上,
http://play.golang.org/p/8OAbtn6koN
一个方法包含缓冲通道,我希望它执行得更好,因为它不等待同步。
ch := make(chan int, 2)
对随机数数组求和的三种方法。我对这三个函数进行了基准测试,如下链接:
http://play.golang.org/p/JK3yL4QwOJ
我的期望是缓冲通道是异步的,除非通道已满,否则发送或接收无需等待,因此缓冲通道总和比无缓冲通道总和性能更好,因为它不需要任何时间来同步所有 goroutine。
[问题 1] 所以我给缓冲通道求和函数提供了 3 个缓冲区大小,但基准测试结果如下:
Benchmarklinear 10 122170091 ns/op
BenchmarkchSum 20 121921287 ns/op
testing: BenchmarkchSum left GOMAXPROCS set to 4
BenchmarkchSumBuffer 20 118524619 ns/op
testing: BenchmarkchSumBuffer left GOMAXPROCS set to 4
ok ~/Benchmark_sum_01 4.056s
这没有意义,为什么在这种情况下两个通道和执行相同?带缓冲的那个应该表现更好吗?
[问题2]
如果我给了
ch := make(chan int, 1)
我明白了
Benchmarklinear 10 122170091 ns/op
BenchmarkchSum 20 121921287 ns/op
testing: BenchmarkchSum left GOMAXPROCS set to 4
BenchmarkchSumBuffer 10 118524619 ns/op
testing: BenchmarkchSumBuffer left GOMAXPROCS set to 4
如果我给了
ch := make(chan int, 2)
我明白了
Benchmarklinear 10 122170091 ns/op
BenchmarkchSum 10 121921287 ns/op
testing: BenchmarkchSum left GOMAXPROCS set to 4
BenchmarkchSumBuffer 20 118524619 ns/op
testing: BenchmarkchSumBuffer left GOMAXPROCS set to 4
但是结果很不一致。每次我运行基准测试,我都会得到不同的结果。
缓冲区大小与性能无关?为什么缓冲区大小为 2 的基准测试给了我不同的结果。随着缓冲区大小的增加,两个 goroutine 永远不会阻塞,因此似乎花费的时间更少。
提前致谢。
【问题讨论】:
标签: concurrency go buffer benchmarking channel