查看完整版本: [-- Qt debug和release模式问题 --]

QTCN开发网 -> Qt基础编程 -> Qt debug和release模式问题 [打印本页] 登录 -> 注册 -> 回复主题 -> 发表主题

songhuirong1 2017-07-30 12:54

Qt debug和release模式问题

测试了一段代码的执行效率,代码如下:
  1. 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;
发现在debug模式下运行速度非常慢,需要几个小时,但是如果在release模式下运行的话,不到1ms就完成了。为什么差距会这么大?望高人指点。

songhuirong1 2017-08-01 10:16
高人呢

dbzhang800 2017-08-01 13:02
这和人一样,你让一个刚学会加法的小学生和一个高中生,分别计算 0+1+2+3+...+99 的结果是多少。正常来说,所用的时间差别肯定非常大。当然,你可以让高中生挨个数进行累加,但默认应该都不会这么干。

同样,你在release模式下编译程序时,你也可以关掉优化选项,让它老老实实执行这么多次加法和循环。

songhuirong1 2017-08-02 12:28
dbzhang800:这和人一样,你让一个刚学会加法的小学生和一个高中生,分别计算 0+1+2+3+...+99 的结果是多少。正常来说,所用的时间差别肯定非常大。当然,你可以让高中生挨个数进行累加,但默认应该都不会这么干。
同样,你在release模式下编译程序时,你也可以关掉优化选项,让它老老实实执 .. (2017-08-01 13:02) 

我们平常所说的程序执行效率,指的是优化后的,还是没有优化过的?

dosmlp 2017-08-03 09:02
编译器在debug模式下会严格按照代码写的进行编译,release模式则会进行代码优化


查看完整版本: [-- Qt debug和release模式问题 --] [-- top --]



Powered by phpwind v8.7 Code ©2003-2011 phpwind
Gzip disabled