VC6.0和BCB6.0中STL的性能比较(3)

王朝vc·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

pair的测试

测试内容:

测试了pair和makepair

所有测试都是都是做了10000次循环的结果。

VC6.0的测试结果:

title con/des makepair less greater equal !equal

ticks 102792 102480 180324 180648 140416 140156

ms 5.6352e-002 5.6181e-002 9.8857e-002 9.9034e-002 7.6978e-002 7.6836e-002

BCB6.0的测试结果:

title con/des makepair less greater equal !equal

ticks 36604 35296 15272 20272 20300 20304

ms 1.9443e-02 1.8748e-02 8.1120e-03 1.0768e-02 1.0783e-02 1.0785e-02

说明:1.这个结果是4次测试后的最小值集合,而不是在一次测试中完成的。

2.VC编译器默认选项inline是关闭的,应该用/Ob2选项打开。最初我就犯了这个错误。使用STL的时候,一定要打开这个选项,性能会得到数倍的提高(在这个测试中是这样的)。

比较结果:

BCB6.0全面胜出。某些测试几乎是一个数量级的性能差距,哪怕是个对性能只有一点点在意的人,都是致命的诱惑吧?

分析:

两者之间的差距已经没必要多说什么了,还是看看他们内部的比较吧。

令我不明白的是,makepair比直接构造pair对象要快。不管明不明白,makepair既方便,又高效,不用白不用。

对于VC来说,互相可简单转换的操作,性能差别不大。BCB中,"<"操作明显优于">",不明白为什么。要知道,两者的代码几乎是一模一样的。如果那位明白为什么,请指教。

auto_ptr的测试

测试内容:

所有测试都是都是做了10000次循环的结果。

VC6.0的测试结果:

title con/des new/del nor get ref nor ref get ptr

ticks 7840740 7787308 50220 57084 50128

ms 4.3133e+000 4.2701e+000 2.7662e-002 3.1301e-002 2.7487e-002

BCB6.0的测试结果:

title con/des new/del nor get ref nor ref get ptr

ticks 2403280 204910 20268 15288 15272

ms 1.3221e+00 1.1272e+00 1.1150e-02 8.4101e-03 8.4013e-03

说明:1.这个结果是4次测试后的最小值集合,而不是在一次测试中完成的。

2.有nor的列表示原始的指针操作。例如:分配 p = new *int; 取引用 *p;

比较结果:

BCB6.0全面胜出。结合内存分配操作的结果,我认为,auto_ptr和pair的测试应该认为是编译器的较量。BCB比较

接近我从理论上推测的结果。

分析:

要说明的是,这里面有内存分配操作的影响,这也是我为什么要为内存分配操作做单独测试的原因。

使用auto_ptr和裸指针的效率差不多。其实,在我的大量测试中,绝大多数情况下,都是aotu_ptr小胜。只是BCB中的取引用裸指针占优。

看了前面的测试是不是觉得不可思议?我也是。似乎一切都对BCB和STL太有利了,甚至连我也怀疑起自己来。可是,数据铁证如山,认命吧!

完成了这些琐碎的测试,终于可以开始最想做的工作了:对容器和迭代器的测试,紧接着,将是vector和list的测试。会有什么结果呢?我现在也是不得而知。但我相信,一定会有一些不可思议的事情发生。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有  導航