新浪微博
腾讯微博
会员列表
统计排行
基本信息
到访IP统计
管理团队
管理统计
在线会员
会员排行
版块排行
帖子排行
标签排行
帮助
下拉
用户名
电子邮箱
用户名
密 码
记住登录
登录
找回密码
注册
快捷通道
关闭
您还没有登录,快捷通道只有在登录后才能使用。
立即登录
还没有帐号? 赶紧
注册一个
首页
论坛
Qt下载
作品展
群组
个人中心
捐赠、管理与开发
邮件订阅
帖子
文章
日志
用户
版块
群组
帖子
搜索
QTCN开发网
>
Qt基础编程
>
qt执行速度问题,4种写法对比
发帖
回复
返回列表
新帖
4772
阅读
6
回复
[讨论]
qt执行速度问题,4种写法对比
[复制链接]
上一主题
下一主题
离线
hitler++
UID:115024
注册时间
2011-04-13
最后登录
2024-02-19
在线时间
1051小时
发帖
264
搜Ta的帖子
精华
0
金钱
2766
威望
282
贡献值
2
好评度
272
访问TA的空间
加好友
用道具
侠客
关闭
个人中心可以申请新版勋章哦
立即申请
知道了
加关注
发消息
只看楼主
倒序阅读
楼主
发表于: 2012-02-19
测试环境:
win7
8G内存
I7 2600 4核8线程CPU
qt4.7.4
php5.3.8
python 2.6
qt下
执行
复制代码
QTime t;
t.start();
QString aa="";
for(int i=0;i<=1000000;i++){
aa += "1";
}
printf("消耗时间: %d 毫秒", t.elapsed());
debug 下耗时:平均240毫秒
release下耗时:平均138毫秒
php下执行
复制代码
$time = new runtime;
$time->start();
$str = "";
for ($i = 0; $i <= 1000000; $i++) {
$str.="1";
}
$time->stop();
echo "使用时间:" . $time->spent() . "毫秒";
平均消耗时间:92.9毫秒
python下执行
复制代码
import os,sys
from time import clock as now
start = now()
str = ""
for i in range(0,1000000):
str += "i"
finish = now()
print (finish-start)
平均消耗时间:210毫秒
纯
C++
代码执行:
复制代码
QTime t;
t.start();
char *pStr = new char[1000001];
for(int i=0;i<=1000000;i++){
pStr[i] = '1';
}
delete pStr;
printf("消耗时间: %d 毫秒",t.elapsed());
debug下,平均3毫秒
release下,平均1毫秒
不止这一种测试,每次测试速度都只能比python快那么点,连php一半的速度都达不到,是我qt配置
问题
还是什么问题.
比纯c++代码甚至慢上了几百倍,求解,这是一个非常严重的问题
共
条评分
回复
举报
分享到
淘江湖
新浪
QQ微博
QQ空间
开心
人人
豆瓣
网易微博
百度
鲜果
白社会
飞信
离线
roywillow
UID:97396
注册时间
2010-05-15
最后登录
2021-09-20
在线时间
5071小时
发帖
2897
搜Ta的帖子
精华
5
金钱
29175
威望
2924
贡献值
2
好评度
2916
访问TA的空间
加好友
用道具
精灵王
加关注
发消息
只看该作者
1楼
发表于: 2012-02-19
先调用一下QString::reserve()一下试试呢?
另外也可以参考一下QString文档的More Efficient String Construction部分
共
条评分
专业维修核潜艇,回收二手航母、二手航天飞机,大修核反应堆,拆洗导弹发动机更换机油,无人侦察机手动挡改自动,航天飞机保养换三滤,飞碟外太空年检 ,各型号导弹加装迎宾踏板,高空作业擦洗卫星表面除尘、打蜡及抛光,东风全系列巡航导弹。并提供原子对撞机。量大从优,有正规发票。
回复
举报
离线
jdwx
UID:107742
注册时间
2010-11-12
最后登录
2016-02-01
在线时间
4619小时
发帖
2939
搜Ta的帖子
精华
0
金钱
30465
威望
3015
贡献值
0
好评度
3005
访问TA的空间
加好友
用道具
论坛版主
加关注
发消息
只看该作者
2楼
发表于: 2012-02-19
QString本身就是个STL的list,动态分配内存本身就很费时间。
你可以用C写个list试试看速度怎么样。
和C++的数组最相似的是STL的vector,一次分配全部的内存。
共
条评分
发帖时要说明:操作系统、Qt版本、编译器,这样能更快的得到回复。
回复
举报
离线
ffii4455
UID:117951
注册时间
2011-06-13
最后登录
2020-10-19
在线时间
344小时
发帖
171
搜Ta的帖子
精华
0
金钱
1770
威望
186
贡献值
0
好评度
176
访问TA的空间
加好友
用道具
侠客
加关注
发消息
只看该作者
3楼
发表于: 2012-02-19
回 2楼(jdwx) 的帖子
同意楼上的说法你纯C++中的代码,内存空间是一次分配好的,而且是连续的内存空间
共
条评分
回复
举报
离线
hitler++
UID:115024
注册时间
2011-04-13
最后登录
2024-02-19
在线时间
1051小时
发帖
264
搜Ta的帖子
精华
0
金钱
2766
威望
282
贡献值
2
好评度
272
访问TA的空间
加好友
用道具
侠客
加关注
发消息
只看该作者
4楼
发表于: 2012-02-20
我试了下 reserve(),好像什么变化也没有
共
条评分
回复
举报
离线
hitler++
UID:115024
注册时间
2011-04-13
最后登录
2024-02-19
在线时间
1051小时
发帖
264
搜Ta的帖子
精华
0
金钱
2766
威望
282
贡献值
2
好评度
272
访问TA的空间
加好友
用道具
侠客
加关注
发消息
只看该作者
5楼
发表于: 2012-02-20
同样,我试了改成标准库的 std::string ,debug下能跑到26毫秒,release下6毫秒
共
条评分
回复
举报
离线
hitler++
UID:115024
注册时间
2011-04-13
最后登录
2024-02-19
在线时间
1051小时
发帖
264
搜Ta的帖子
精华
0
金钱
2766
威望
282
贡献值
2
好评度
272
访问TA的空间
加好友
用道具
侠客
加关注
发消息
只看该作者
6楼
发表于: 2012-02-20
我又用string类和qstring写了相同一个功能的字符串处理函数,但是我却发现2个函数执行速度相差很小,平均50毫秒,string类,大概只能快5毫秒左右
共
条评分
回复
举报
发帖
回复
返回列表
http://www.qtcn.org/bbs
访问内容超出本站范围,不能确定是否安全
继续访问
取消访问
快速回复
限100 字节
您目前还是游客,请
登录
或
注册
进入高级模式
文字颜色
发 布
回复后跳转到最后一页
上一个
下一个
关闭
补充发布信息
验证码:
发 布
隐藏
快速跳转
站务及资讯
网站公告
新闻资讯
Qt官方发布
网站管理
Qt应用及资源
Qt 作品展
Qt代码秀
Qt应用版
Qt技术讨论区
Qt安装与发布
Qt中文处理
Qt基础编程
Qt QML开发
Qt嵌入式开发
Qt移动平台开发
其它技术开发讨论区
Qt图书专区
《C++ GUI Qt 4编程》(第2版)专栏
《Qt高级编程》专栏
《零基础学Qt4编程》专栏
《Qt设计模式》(第2版) 图书专栏
Python Qt GUI快速编程
Qt项目开发区
天池项目
Qt开放平台开发库
Qt版百度云笔记
机械CAD
Qt文档计划
QTCN网站系统开发
扇贝词典
非活跃项目区
社区中心
帖子回收站(Trash)
招聘、求职、供求、广告等
休闲娱乐
关闭
关闭
选中
1
篇
全选