-3

我已经测试了 golang 在 for 循环上的执行情况

仅在 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)
}
4

1 回答 1

8

你没有测量你认为你正在测量的东西,这就是为什么你会得到“令人惊讶”的结果。

您正在计时格式化和打印字符串需要多长时间,而不是“for 循环有多快”。

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

最后,如果您尝试对完全不执行任何操作的循环的性能进行微基准测试,编译器可以检测到这一点并简单地完全优化循环,让您无需测量任何东西......

在大多数情况下,这些孤立的微基准是没有用的。如果你想比较 Python 和 Go 的性能,最好测试一个真实的问题而不是人为的东西。然后不仅比较原始性能,还比较一般代码质量的其他特征。

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

于 2020-06-05T02:28:22.257 回答