免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3609 | 回复: 8
打印 上一主题 下一主题

使用STL的程序,Windows下比Linux下慢很多怎么办 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-06-15 11:30 |只看该作者 |倒序浏览
本帖最后由 reiase 于 2011-06-15 11:34 编辑

如题,程序在Linux/GCC 4.5下速度很快,大概1秒

在VC下,跑了10分钟不见结果出来啊
后来换了mingw编译器,结果一样滴慢

整个程序就300来行,只用了Vector,pair和结构体
大概定义如下:
struct{
int a;
double b;
vector< pair<int, int> >c;
} typeA;

struct{
int a;
double b;
vector< typeA >c;
} typeB;

求大牛帮忙分析原因

论坛徽章:
0
2 [报告]
发表于 2011-06-15 11:58 |只看该作者
源码

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
3 [报告]
发表于 2011-06-15 13:01 |只看该作者
这个,差别能有这么大?

论坛徽章:
0
4 [报告]
发表于 2011-06-15 13:05 |只看该作者
基本不可能。
难道能说明Windows比Linux性能差?或者说Windows的STL库比Linux下的STD库性能差?

描述清楚测试场景包括机器的配置,软件环境的版本,编译选项。

论坛徽章:
2
白羊座
日期:2013-11-18 19:52:42辰龙
日期:2014-09-07 07:46:06
5 [报告]
发表于 2011-06-15 13:07 |只看该作者
分段计时找出最耗时的部分!

论坛徽章:
0
6 [报告]
发表于 2011-06-15 13:39 |只看该作者
本帖最后由 reiase 于 2011-06-15 13:42 编辑

头文件

  1. typedef struct {
  2.         int length;
  3.         double threshold;
  4.         double alpha;
  5.         vector< pair<int, int> > svector;
  6. } cc1;

  7. typedef struct {
  8.         int length;
  9.         double threshold;
  10.         vector< cc1> cls;
  11. } cc2;

  12. typedef struct {
  13.         int length;
  14.         vector< cc2> cls;
  15. } cc3;
复制代码
代码

  1. inline int run_cc1(cc1&h, int *im){
  2.     double retval = 0;
  3.     for (auto i = h.svector.begin(); i != h.svector.end(); i++){
  4.         retval += im[i->first] * i->second;
  5.     }
  6.     return (retval > (h.threshold)) ? +1 : -1;
  7. }

  8. inline int run_cc2(cc2&v, int *im){
  9.     double val = 0;
  10.     for (auto i = v.cls.begin(); i != v.cls.end(); i++)
  11.         val += i->alpha * run_cc1(*i, im);
  12.     predict_result = val;
  13.     return  (val > (v.threshold)) ? +1 : -1;
  14. }

  15. int run_cc3(cc3*c, int *im)
  16. {
  17.     int count = 0;
  18.     for (auto i = c->cls.begin(); i != c->cls.end(); i++){
  19.         if (run_cc2(*i, im) == -1)
  20.             return -count;
  21.         count++;
  22.     }
  23.     return +1;
  24. }
复制代码
硬件配置:core2/2G
Linux环境:Gentoo/gcc4.5.2
Windows环境两个:VC2008/VC2010+Win7,或者mingw gcc4.5.2+Win7

使用GCC时的编译选项:g++ -std=c++0x -march=native -O2
Win7和Linux下都是这个选项
程序跑了一个小时还没结果,郁闷死了啊

论坛徽章:
38
2017金鸡报晓
日期:2017-02-08 10:39:4215-16赛季CBA联赛之深圳
日期:2023-02-16 14:39:0220周年集字徽章-年
日期:2022-08-31 14:25:28黑曼巴
日期:2022-08-17 18:57:0919周年集字徽章-年
日期:2022-04-25 13:02:5920周年集字徽章-20	
日期:2022-03-29 11:10:4620周年集字徽章-年
日期:2022-03-14 22:35:1820周年集字徽章-周	
日期:2022-03-09 12:51:3220周年集字徽章-年
日期:2022-02-10 13:13:4420周年集字徽章-周	
日期:2022-02-03 12:09:4420周年集字徽章-20	
日期:2022-01-25 20:14:2720周年集字徽章-周	
日期:2022-01-13 15:12:33
7 [报告]
发表于 2011-06-15 19:52 |只看该作者
基本没差别

论坛徽章:
0
8 [报告]
发表于 2011-06-15 22:17 |只看该作者
这个代码结构设计:vector< cc2> cls; vector当数据量大时,如果没有预先分配这类动态分配效率会很差的,vc和gcc的stl版本都是HP STL的分支。效率应该不会差太远。

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:56:11
9 [报告]
发表于 2011-06-15 22:44 |只看该作者
簡單方法,換stlport試驗下。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP