为什么 Golang for loop 比 Python for loop 慢?



我已经测试了golang在for loop上的表现

在 python 和 golang 中循环了 50,000 次,我发现在 python 中需要 0.59 秒,而在 golang 中需要 9.12 秒

任何有经验的 go 开发人员都可以告诉我为什么 Golang 在编译语言时在 for 循环中太慢了吗?


import (
"fmt"
"time"
)
func main()  {
start := time.Now()
for i := 0; i < 50000; i++ {
fmt.Println("Index", i)
}
finish := time.Now().Sub(start).Seconds()
fmt.Printf("Elapsed time was %.2f seconds.n", finish)
}

你没有衡量你认为你在测量什么,这就是为什么你会得到"令人惊讶"的结果。

您正在计时格式化和打印字符串所需的时间,而不是"for 循环有多快"。

另外,请记住,测量打印内容所需的时间不仅取决于代码的编译/解释方式,还取决于打印的确切位置:I/O性能取决于程序之外的内容(可能是操作系统,也许是某些物理设备等(。

最后,如果你试图对一个完全不做任何事情的循环的性能进行微基准测试,编译器可以检测到这一点,并简单地完全优化循环,让你不测量任何东西......

大多数时候,这些孤立的微观基准是没有用的。如果你想在性能方面比较Python和Go,通常最好在实际问题上进行测试,而不是人为的问题。然后不仅比较原始性能,还比较代码质量的其他特征。

最重要的是,这个基准有太多错误,无法得出任何有用的结论。

最新更新