托管代码和非托管代码效率的对比。

原文地址为: 托管代码和非托管代码效率的对比。

 一直以来只知道托管代码效率要比非托管代码低,至于低多少也没有可参考的数据。今天在csdn看到的英特尔多核平台编程优化大赛的广告,把里面的代码下载回来,分别用非托管c/托管cpp/c#做了个简略的性能测试,不比不知道,一比吓了一跳。且看数据说话。

 

第一步:原始代码如:

24a924a57ba6b3f2b51fc9edb7ea4186.jpe 9310e85a14af99de4811ff4c77f1f911.jpe /**/ /* compute the potential energy of a collection of */
24a924a57ba6b3f2b51fc9edb7ea4186.jpe9310e85a14af99de4811ff4c77f1f911.jpe
/**/ /* particles interacting via pairwise potential    */
731655954c7be9d8835ece551b5385f8.jpe 
731655954c7be9d8835ece551b5385f8.jpe#include 
< stdio.h >
731655954c7be9d8835ece551b5385f8.jpe#include 
< stdlib.h >
731655954c7be9d8835ece551b5385f8.jpe#include 
< math.h >
731655954c7be9d8835ece551b5385f8.jpe#include 
< windows.h >
731655954c7be9d8835ece551b5385f8.jpe#include 
< time.h >
731655954c7be9d8835ece551b5385f8.jpe 
731655954c7be9d8835ece551b5385f8.jpe
#define  NPARTS 1000
731655954c7be9d8835ece551b5385f8.jpe
#define  NITER 201
731655954c7be9d8835ece551b5385f8.jpe
#define  DIMS 3
731655954c7be9d8835ece551b5385f8.jpe 
731655954c7be9d8835ece551b5385f8.jpe
int  rand(  void  );
731655954c7be9d8835ece551b5385f8.jpe
int  computePot( void );
731655954c7be9d8835ece551b5385f8.jpe
void  initPositions( void );
731655954c7be9d8835ece551b5385f8.jpe
void  updatePositions( void );
731655954c7be9d8835ece551b5385f8.jpe 
731655954c7be9d8835ece551b5385f8.jpe
double  r[DIMS][NPARTS];
731655954c7be9d8835ece551b5385f8.jpe
double  pot;
731655954c7be9d8835ece551b5385f8.jpe
double  distx, disty, distz, dist;
731655954c7be9d8835ece551b5385f8.jpe
24a924a57ba6b3f2b51fc9edb7ea4186.jpe9310e85a14af99de4811ff4c77f1f911.jpe
int  main()  222530190136c9c4cfd237cc0d5cff99.jpe {
1408c5260b2f05e450dee929db9be5f7.jpe   
int i;
1408c5260b2f05e450dee929db9be5f7.jpe   clock_t start, stop;
1408c5260b2f05e450dee929db9be5f7.jpe
1408c5260b2f05e450dee929db9be5f7.jpe   initPositions();
1408c5260b2f05e450dee929db9be5f7.jpe   updatePositions();
1408c5260b2f05e450dee929db9be5f7.jpe 
1408c5260b2f05e450dee929db9be5f7.jpe   start
=clock();
715f2d05503b99d41f3b6ba2cdccc84d.jpee083dfde5a91f50979fe8979b4012b9d.jpe   
for( i=0; i<NITER; i++ ) 222530190136c9c4cfd237cc0d5cff99.jpe{
1408c5260b2f05e450dee929db9be5f7.jpe      pot 
= 0.0;
1408c5260b2f05e450dee929db9be5f7.jpe      computePot();
1408c5260b2f05e450dee929db9be5f7.jpe      
if (i%10 == 0) printf("%5d: Potential: %10.3f\n", i, pot);
1408c5260b2f05e450dee929db9be5f7.jpe      updatePositions();
5bcb1807ee3e00d2b3c225f0b3f5c751.jpe   }

1408c5260b2f05e450dee929db9be5f7.jpe   stop
=clock();
1408c5260b2f05e450dee929db9be5f7.jpe   printf (
"Seconds = %10.9f\n",(double)(stop-start)/ CLOCKS_PER_SEC);
1408c5260b2f05e450dee929db9be5f7.jpe   
int e;
1408c5260b2f05e450dee929db9be5f7.jpe   scanf(
"%d",&e);
f466905a3bcb5dcef110eab799825254.jpe}

731655954c7be9d8835ece551b5385f8.jpe 
731655954c7be9d8835ece551b5385f8.jpe 
24a924a57ba6b3f2b51fc9edb7ea4186.jpe9310e85a14af99de4811ff4c77f1f911.jpe
void  initPositions()  222530190136c9c4cfd237cc0d5cff99.jpe {
1408c5260b2f05e450dee929db9be5f7.jpe   
int i, j;
1408c5260b2f05e450dee929db9be5f7.jpe 
1408c5260b2f05e450dee929db9be5f7.jpe   
for( i=0; i<DIMS; i++ )
1408c5260b2f05e450dee929db9be5f7.jpe      
for( j=0; j<NPARTS; j++ ) 
1408c5260b2f05e450dee929db9be5f7.jpe         r[i][j] 
= 0.5 + ( (double) rand() / (double) RAND_MAX );
f466905a3bcb5dcef110eab799825254.jpe}

731655954c7be9d8835ece551b5385f8.jpe 
731655954c7be9d8835ece551b5385f8.jpe 
24a924a57ba6b3f2b51fc9edb7ea4186.jpe9310e85a14af99de4811ff4c77f1f911.jpe
void  updatePositions()  222530190136c9c4cfd237cc0d5cff99.jpe {
1408c5260b2f05e450dee929db9be5f7.jpe   
int i, j;
1408c5260b2f05e450dee929db9be5f7.jpe 
1408c5260b2f05e450dee929db9be5f7.jpe   
for( i=0; i<DIMS; i++ )
1408c5260b2f05e450dee929db9be5f7.jpe      
for( j=0; j<NPARTS; j++ )
1408c5260b2f05e450dee929db9be5f7.jpe         r[i][j] 
-= 0.5 + ( (double) rand() / (double) RAND_MAX );
f466905a3bcb5dcef110eab799825254.jpe}

731655954c7be9d8835ece551b5385f8.jpe 
731655954c7be9d8835ece551b5385f8.jpe 
24a924a57ba6b3f2b51fc9edb7ea4186.jpe9310e85a14af99de4811ff4c77f1f911.jpe
int  computePot()  222530190136c9c4cfd237cc0d5cff99.jpe {
1408c5260b2f05e450dee929db9be5f7.jpe   
int i, j;
1408c5260b2f05e450dee929db9be5f7.jpe
715f2d05503b99d41f3b6ba2cdccc84d.jpee083dfde5a91f50979fe8979b4012b9d.jpe   
for( i=0; i<NPARTS; i++ ) 222530190136c9c4cfd237cc0d5cff99.jpe{
715f2d05503b99d41f3b6ba2cdccc84d.jpee083dfde5a91f50979fe8979b4012b9d.jpe      
for( j=0; j<i-1; j++ ) 222530190136c9c4cfd237cc0d5cff99.jpe{
1408c5260b2f05e450dee929db9be5f7.jpe        distx 
= pow( (r[0][j] - r[0][i]), 2 );
1408c5260b2f05e450dee929db9be5f7.jpe        disty 
= pow( (r[1][j] - r[1][i]), 2 );
1408c5260b2f05e450dee929db9be5f7.jpe        distz 
= pow( (r[2][j] - r[2][i]), 2 );
1408c5260b2f05e450dee929db9be5f7.jpe        dist 
= sqrt( distx + disty + distz );
1408c5260b2f05e450dee929db9be5f7.jpe        pot 
+= 1.0 / dist;
5bcb1807ee3e00d2b3c225f0b3f5c751.jpe      }

5bcb1807ee3e00d2b3c225f0b3f5c751.jpe   }

1408c5260b2f05e450dee929db9be5f7.jpe   
return 0;
f466905a3bcb5dcef110eab799825254.jpe}

731655954c7be9d8835ece551b5385f8.jpe


执行结果如下:

aa61b622dfa95543873fe23b50322d94.jpe

执行时间4.609s。

 

 第二步:托管

新建一个 C++ CLR Console Aplication,命名为mcpp。打开mcpp.cpp文件,将原始代码粘贴进来即可(代码太长这里就不贴出来了,可以在全贴下面的下载全部源码)。

执行结果如下:

e28c87f925005f0cba7d1f93a6bc0e2c.jpe

执行时间:15.1720s。

 

第二步:c#

笔者将原始代码翻译成CS代码,如下:

731655954c7be9d8835ece551b5385f8.jpe using  System;
731655954c7be9d8835ece551b5385f8.jpe
using  System.Collections.Generic;
731655954c7be9d8835ece551b5385f8.jpe
using  System.Text;
731655954c7be9d8835ece551b5385f8.jpe
731655954c7be9d8835ece551b5385f8.jpe
731655954c7be9d8835ece551b5385f8.jpe
namespace  cs
24a924a57ba6b3f2b51fc9edb7ea4186.jpe9310e85a14af99de4811ff4c77f1f911.jpe
222530190136c9c4cfd237cc0d5cff99.jpe {
1408c5260b2f05e450dee929db9be5f7.jpe    
class Program
715f2d05503b99d41f3b6ba2cdccc84d.jpee083dfde5a91f50979fe8979b4012b9d.jpe    
222530190136c9c4cfd237cc0d5cff99.jpe{
1408c5260b2f05e450dee929db9be5f7.jpe        
private const int RAND_MAX = 0x7fff;
1408c5260b2f05e450dee929db9be5f7.jpe        
private const int NPARTS = 1000;
1408c5260b2f05e450dee929db9be5f7.jpe        
private const int NITER = 201;
1408c5260b2f05e450dee929db9be5f7.jpe        
private const int DIMS = 3;
1408c5260b2f05e450dee929db9be5f7.jpe        
private double pot;
1408c5260b2f05e450dee929db9be5f7.jpe        
private double distx, disty, distz, dist;
1408c5260b2f05e450dee929db9be5f7.jpe        
private Random random = new Random(Environment.TickCount);
1408c5260b2f05e450dee929db9be5f7.jpe        
private double[][] r = new double[DIMS][];
1408c5260b2f05e450dee929db9be5f7.jpe
1408c5260b2f05e450dee929db9be5f7.jpe        
public void main()
715f2d05503b99d41f3b6ba2cdccc84d.jpee083dfde5a91f50979fe8979b4012b9d.jpe        
222530190136c9c4cfd237cc0d5cff99.jpe{
1408c5260b2f05e450dee929db9be5f7.jpe            
int i;
1408c5260b2f05e450dee929db9be5f7.jpe            
int start, stop;
1408c5260b2f05e450dee929db9be5f7.jpe
1408c5260b2f05e450dee929db9be5f7.jpe            
for (int ii = 0; ii < DIMS; ii++)
715f2d05503b99d41f3b6ba2cdccc84d.jpee083dfde5a91f50979fe8979b4012b9d.jpe            
222530190136c9c4cfd237cc0d5cff99.jpe{
1408c5260b2f05e450dee929db9be5f7.jpe                r[ii] 
= new double[NPARTS];
5bcb1807ee3e00d2b3c225f0b3f5c751.jpe            }

1408c5260b2f05e450dee929db9be5f7.jpe
1408c5260b2f05e450dee929db9be5f7.jpe            initPositions();
1408c5260b2f05e450dee929db9be5f7.jpe            updatePositions();
1408c5260b2f05e450dee929db9be5f7.jpe
1408c5260b2f05e450dee929db9be5f7.jpe            start 
= Environment.TickCount;
1408c5260b2f05e450dee929db9be5f7.jpe            
for (i = 0; i < NITER; i++)
715f2d05503b99d41f3b6ba2cdccc84d.jpee083dfde5a91f50979fe8979b4012b9d.jpe            
222530190136c9c4cfd237cc0d5cff99.jpe{
1408c5260b2f05e450dee929db9be5f7.jpe                pot 
= 0.0;
1408c5260b2f05e450dee929db9be5f7.jpe                computePot();
1408c5260b2f05e450dee929db9be5f7.jpe                
if (i % 10 == 0)
1408c5260b2f05e450dee929db9be5f7.jpe                    Console.WriteLine(
"{0}: Potential: {1:##########.###}", i, pot);
1408c5260b2f05e450dee929db9be5f7.jpe                updatePositions();
5bcb1807ee3e00d2b3c225f0b3f5c751.jpe            }

1408c5260b2f05e450dee929db9be5f7.jpe            stop 
= Environment.TickCount;
1408c5260b2f05e450dee929db9be5f7.jpe            Console.WriteLine(
"Seconds = {0:##########.#########}", (double)(stop - start)/1000);
5bcb1807ee3e00d2b3c225f0b3f5c751.jpe        }

1408c5260b2f05e450dee929db9be5f7.jpe
1408c5260b2f05e450dee929db9be5f7.jpe        
private void computePot()
715f2d05503b99d41f3b6ba2cdccc84d.jpee083dfde5a91f50979fe8979b4012b9d.jpe        
222530190136c9c4cfd237cc0d5cff99.jpe{
1408c5260b2f05e450dee929db9be5f7.jpe            
int i, j;
1408c5260b2f05e450dee929db9be5f7.jpe
1408c5260b2f05e450dee929db9be5f7.jpe            
for (i = 0; i < NPARTS; i++)
715f2d05503b99d41f3b6ba2cdccc84d.jpee083dfde5a91f50979fe8979b4012b9d.jpe            
222530190136c9c4cfd237cc0d5cff99.jpe{
1408c5260b2f05e450dee929db9be5f7.jpe                
for (j = 0; j < i - 1; j++)
715f2d05503b99d41f3b6ba2cdccc84d.jpee083dfde5a91f50979fe8979b4012b9d.jpe                
222530190136c9c4cfd237cc0d5cff99.jpe{
1408c5260b2f05e450dee929db9be5f7.jpe                    distx 
= Math.Pow((r[0][j] - r[0][i]), 2);
1408c5260b2f05e450dee929db9be5f7.jpe                    disty 
= Math.Pow((r[1][j] - r[1][i]), 2);
1408c5260b2f05e450dee929db9be5f7.jpe                    distz 
= Math.Pow((r[2][j] - r[2][i]), 2);
1408c5260b2f05e450dee929db9be5f7.jpe                    dist 
= Math.Sqrt(distx + disty + distz);
1408c5260b2f05e450dee929db9be5f7.jpe                    pot 
+= 1.0 / dist;
5bcb1807ee3e00d2b3c225f0b3f5c751.jpe                }

5bcb1807ee3e00d2b3c225f0b3f5c751.jpe            }

5bcb1807ee3e00d2b3c225f0b3f5c751.jpe        }

1408c5260b2f05e450dee929db9be5f7.jpe
1408c5260b2f05e450dee929db9be5f7.jpe        
private void updatePositions()
715f2d05503b99d41f3b6ba2cdccc84d.jpee083dfde5a91f50979fe8979b4012b9d.jpe        
222530190136c9c4cfd237cc0d5cff99.jpe{
1408c5260b2f05e450dee929db9be5f7.jpe            
int i, j;
1408c5260b2f05e450dee929db9be5f7.jpe
1408c5260b2f05e450dee929db9be5f7.jpe            
for (i = 0; i < DIMS; i++)
1408c5260b2f05e450dee929db9be5f7.jpe                
for (j = 0; j < NPARTS; j++)
1408c5260b2f05e450dee929db9be5f7.jpe                    r[i][j] 
-= 0.5 + ((double)random.Next(RAND_MAX)/(double)RAND_MAX);
5bcb1807ee3e00d2b3c225f0b3f5c751.jpe        }

1408c5260b2f05e450dee929db9be5f7.jpe
1408c5260b2f05e450dee929db9be5f7.jpe        
private void initPositions()
715f2d05503b99d41f3b6ba2cdccc84d.jpee083dfde5a91f50979fe8979b4012b9d.jpe        
222530190136c9c4cfd237cc0d5cff99.jpe{
1408c5260b2f05e450dee929db9be5f7.jpe            
int i, j;
1408c5260b2f05e450dee929db9be5f7.jpe            
for (i = 0; i < DIMS; i++)
1408c5260b2f05e450dee929db9be5f7.jpe                
for (j = 0; j < NPARTS; j++)
1408c5260b2f05e450dee929db9be5f7.jpe                    r[i][j] 
= 0.5 + ((double)random.Next(RAND_MAX)/(double)RAND_MAX);
5bcb1807ee3e00d2b3c225f0b3f5c751.jpe        }

1408c5260b2f05e450dee929db9be5f7.jpe
1408c5260b2f05e450dee929db9be5f7.jpe        
static void Main(string[] args)
715f2d05503b99d41f3b6ba2cdccc84d.jpee083dfde5a91f50979fe8979b4012b9d.jpe        
222530190136c9c4cfd237cc0d5cff99.jpe{
1408c5260b2f05e450dee929db9be5f7.jpe            Program p 
= new Program();
1408c5260b2f05e450dee929db9be5f7.jpe            p.main();
1408c5260b2f05e450dee929db9be5f7.jpe            Console.ReadLine();
1408c5260b2f05e450dee929db9be5f7.jpe
5bcb1807ee3e00d2b3c225f0b3f5c751.jpe        }

5bcb1807ee3e00d2b3c225f0b3f5c751.jpe    }

f466905a3bcb5dcef110eab799825254.jpe}

731655954c7be9d8835ece551b5385f8.jpe

执行结果如下:

 
执行时间:62.453s!
 
第四、数据比较
非托管C:  4.609s
托管cpp: 15.720s
托管c#:  62.453s
 PS机器配置:p4 3.0G双核,1G内存
 

全部代码下载


转载请注明本文地址: 托管代码和非托管代码效率的对比。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值