Python:通過執行100萬次打印來比較C和python的性能,以及用C和python結合來解決性能問題的方法 .


 python作為動態語言,開發效率相當高,但如我們所知,動態語言的執行效率往往是比較低的,請看下面簡單的測試過程:

 一、 C語言實現100萬次打印:

  代碼:

  1. #include<stdio.h>   
  2. #include <time.h>   
  3.   
  4. int main(int argc, char* argv[])  
  5. {  
  6.     unsigned long i = 1;  
  7.     unsigned long ulNum = 1000000;  
  8.   
  9.     clock_t start, finish;  
  10.     double  duration;  
  11.   
  12.     start = clock();  
  13.   
  14.     while (ulNum != 0)  
  15.     {  
  16.         printf("\nThe ulNum is: %u ", i);  
  17.         ulNum--;  
  18.         i++;  
  19.     }  
  20.   
  21.     finish = clock();  
  22.     duration = (double)(finish - start) / CLOCKS_PER_SEC;  
  23.     printf( "\n Use Time: %f seconds\n", duration );  
  24.   
  25.     system("pause");  
  26.   
  27.     return 0;  
  28. }  

測試:

可看出,執行了約489秒。

二、python實現100萬次打印:

代碼:

[python] view plain copy print ?
  1. #!/usr/bin/env python   
  2. # -*- coding: utf-8 -*-   
  3.   
  4. import time  
  5. import os  
  6.   
  7. time_begin = time.clock()  
  8.   
  9. i = 1  
  10. ulNum = 1000000  
  11. while (ulNum != 0):  
  12.     print "The ulNum is: %u " % i  
  13.     ulNum -= 1   
  14.     i += 1    
  15. print "Use time: %s" % (time.clock() - time_begin)   
  16. os.system("pause")  


測試:

可看出,執行了約675秒。

 

三、性能問題解決方法:

  通過上面的比較,可以看出,同樣一個算法,C和python執行所需要的時間相差180多秒,所以我們需要一個解決方法,使編程既有python般的開發效率,又有C般的執行效率,所以我們想到如果將python程序中消耗性能最大的語句用C來實現,將會比較好地解決此問題,當然,實現方法可能有多種,本文僅通過python調用dll的方法來實現,其他方法后續再分析。

思路如下:

 1、將程序中循環部分用C實現,並封裝為一個dll;

 2、在python中調用此dll來計算;

 方案實現:

 1、制作dll,使用VC可以很方便的制作一個dll出來,代碼如下,編譯一下就會生成一個test_dll.dll文件,注意編譯成Release版本。

  1. // test_dll.cpp : Defines the entry point for the DLL application.   
  2. //   
  3.   
  4. #include "stdafx.h"   
  5. #include <stdio.h>   
  6.   
  7.   
  8. BOOL APIENTRY DllMain( HANDLE hModule,   
  9.                        DWORD  ul_reason_for_call,   
  10.                        LPVOID lpReserved  
  11.                      )  
  12. {  
  13.     return TRUE;  
  14. }  
  15.   
  16.   
  17. extern "C" _declspec(dllexportvoid print_sum(unsigned long ulNum)   
  18. {   
  19.     unsigned long i = 1;  
  20.   
  21.     while (ulNum != 0)  
  22.     {  
  23.         printf("\nThe ulNum is: %u ", i);  
  24.         ulNum--;  
  25.         i++;  
  26.     }  
  27.   
  28. }  


2、使用python調用test_dll.dll文件,代碼如下:

[python] view plain copy print ?
  1. import os  
  2. import ctypes  
  3. import time  
  4.   
  5.   
  6. time_begin = time.clock()  
  7.   
  8. test_dll = ctypes.cdll.LoadLibrary('test_dll.dll')  
  9.   
  10. test_dll.print_sum(1000000)  
  11.   
  12. print "Use time: %s" % (time.clock() - time_begin)   
  13.   
  14. os.system("pause")  


3、測試一下這次的執行時間:

 這次我們用了507秒,可以看出和C程序運行結果的差不多。

四、后記

  通過pyhton調用dll文件僅是提高性能的一個辦法,如C和python混合編程等方法均可實現此目的,具體請見后續博文。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM