Go语言执行效率

hzsunsong · · 7114 次点击 · 开始浏览    置顶
这是一个创建于 的主题,其中的信息可能已经有所发展或是发生改变。

今天我用Qt和Golang写了一段代码用来对比它们的执行效率,代码很简单,就是求1到1000000000000的和,如下: Qt代码: ```c QElapsedTimer et; et.start(); long sum = 0; for(long i = 0; i < 1000000000000; ++i) { sum += i; } qDebug() << Q_FUNC_INFO << "Elapsed:" << et.elapsed(); qDebug() << Q_FUNC_INFO << "sum =" << sum; ``` Golang代码: ```go package main import "fmt" import "time" func main() { now := time.Now() var sum int64 = 0 var i int64 = 0 for ; i < 1000000000000; i++ { sum = (sum + i) } duration := time.Since(now) fmt.Println("duration:", duration) fmt.Println("sum =", sum) } ``` 分别运行这两段代码,执行时间如下: Qt执行时间: ``` void Sum::seqAdd() Elapsed: 0 void Sum::seqAdd() sum = 1001881602603448320 ``` 不到1ms就执行结束了,速度非常快 Golang执行时间: ``` duration: 8m24.477438418s sum = 1001881602603448320 ``` 这个时间不知道是不是表示8分多钟,但是我当时看着输出的,好像不止8分钟,差不多半个小时才输出结果。 为什么Golang的执行效率如此之低,这个速度让人无法接受。Qt执行这段代码时瞬间就输出了结果,而Golang等了差不多半个小时才输出结果,太慢了。不知道这是为什么,是不是我程序写的有错?Golang不是号称执行速度可以媲美C或C++吗?请大侠指点下。

有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

7114 次点击  
加入收藏 微博
17 回复  |  直到 2017-08-04 00:29:31
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传