Moh*_*del -3 python performance interpreted-language compiled-language go
我已经测试了 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)
}
Run Code Online (Sandbox Code Playgroud)
你没有测量你认为你在测量的东西,这就是为什么你会得到“令人惊讶”的结果。
您正在计算格式化和打印字符串所需的时间,而不是“for 循环有多快”。
此外,请记住,测量打印某些内容所需的时间不仅取决于代码的编译/解释方式,还取决于您打印的确切位置:I/O 性能取决于程序之外的内容(也许操作系统,也许是一些物理设备等)。
最后,如果你试图对一个完全不做任何事情的循环的性能进行微基准测试,编译器可以检测到它并简单地完全优化循环,让你不用测量任何东西......
这些孤立的微基准在大多数情况下是没有用的。如果你想在性能方面比较 Python 和 Go,通常最好测试一个真正的问题而不是一些人为的问题。然后不仅比较原始性能,还比较一般代码质量的其他特征。
最重要的是,这个基准测试错误太多,无法得出任何有用的结论。
| 归档时间: |
|
| 查看次数: |
455 次 |
| 最近记录: |