?python作為動態語言,開發效率相當高,但如我們所知,動態語言的執行效率往往是比較低的,請看下面簡單的測試過程:
### 一、 C語言實現100萬次打印:
代碼:
~~~
#include<stdio.h>
#include <time.h>
int main(int argc, char* argv[])
{
unsigned long i = 1;
unsigned long ulNum = 1000000;
clock_t start, finish;
double duration;
start = clock();
while (ulNum != 0)
{
printf("\nThe ulNum is: %u ", i);
ulNum--;
i++;
}
finish = clock();
duration = (double)(finish - start) / CLOCKS_PER_SEC;
printf( "\n Use Time: %f seconds\n", duration );
system("pause");
return 0;
}
~~~
測試:
可看出,執行了約489秒。

### 二、python實現100萬次打印:
代碼:
~~~
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import time
import os
time_begin = time.clock()
i = 1
ulNum = 1000000
while (ulNum != 0):
print "The ulNum is: %u " % i
ulNum -= 1
i += 1
print "Use time: %s" % (time.clock() - time_begin)
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版本。
~~~
// test_dll.cpp : Defines the entry point for the DLL application.
//
#include "stdafx.h"
#include <stdio.h>
BOOL APIENTRY DllMain( HANDLE hModule,
DWORD ul_reason_for_call,
LPVOID lpReserved
)
{
return TRUE;
}
extern "C" _declspec(dllexport) void print_sum(unsigned long ulNum)
{
unsigned long i = 1;
while (ulNum != 0)
{
printf("\nThe ulNum is: %u ", i);
ulNum--;
i++;
}
}
~~~
2、使用python調用test_dll.dll文件,代碼如下:
~~~
import os
import ctypes
import time
time_begin = time.clock()
test_dll = ctypes.cdll.LoadLibrary('test_dll.dll')
test_dll.print_sum(1000000)
print "Use time: %s" % (time.clock() - time_begin)
os.system("pause")
~~~
3、測試一下這次的執行時間:
這次我們用了507秒,可以看出和C程序運行結果的差不多。

### 四、后記
通過pyhton調用dll文件僅是提高性能的一個辦法,如C和python混合編程等方法均可實現此目的,具體請見后續博文。
- 前言
- Python:實現文件歸檔
- Pyhon:按行輸出文件內容
- Python:讀文件和寫文件
- Python:實現一個小算法
- Python:通過命令行發送新浪微博
- Python:通過攝像頭實現的監控功能
- Python:通過攝像頭抓取圖像并自動上傳至新浪微博
- Python:簡單的攝像頭程序實現
- Python:日志模塊logging的應用
- Python:操作嵌入式數據庫SQLite
- Python:將句子中的單詞全部倒排過來,但單詞的字母順序不變
- Python:語音處理,實現在線朗讀RFC文檔或本地文本文件
- Python:通過計算階乘來學習lambda和reduce這兩個函數的使用
- Python:通過執行100萬次打印來比較C和python的性能,以及用C和python結合來解決性能問題的方法
- Python:使用matplotlib繪制圖表
- Python:使用pycha快速繪制辦公常用圖(餅圖、垂直直方圖、水平直方圖、散點圖等七種圖形)
- Python:使用pycha快速繪制辦公常用圖二(使用樣式定制個性化圖表)
- Python:監控鍵盤輸入、鼠標操作,并將捕獲到的信息記錄到文件中
- Python:通過獲取淘寶賬號和密碼的實驗,來看登陸方式選擇的重要性
- Python:通過獲取淘寶賬號和密碼的實驗,來看登陸方式選擇的重要性(二)
- Python:通過遠程監控用戶輸入來獲取淘寶賬號和密碼的實驗(一)
- Python:通過遠程監控用戶輸入來獲取淘寶賬號和密碼的實驗(二)
- Python:通過自定義系統級快捷鍵來控制程序運行
- Python:通過自定義系統級快捷鍵來控制程序開始或停止記錄日志(使用小技巧解決一個貌似無解的問題)
- Python:一個多功能的抓圖工具開發(附源碼)
- Python:程序發布方式簡介一(打包為可執行文件EXE)
- Python:新浪微博應用開發簡介(認證及授權部分)
- Python:程序最小化到托盤功能實現
- Python:實用抓圖工具開發介紹(含需求分析、設計、編碼、單元測試、打包、系統測試、發布各環節)
- Python:桌面氣泡提示功能實現
- Python:未來三個月的python學習計劃
- Python:pygame模塊及SDL庫簡介
- Python:獲取新浪微博用戶的收聽列表和粉絲列表
- Python:pygame游戲編程之旅一(Hello World)
- Python:pygame游戲編程之旅二(自由移動的小球)
- Python:pygame游戲編程之旅三(玩家控制的小球)
- Python:pygame游戲編程之旅四(游戲界面文字處理)
- Python:pygame游戲編程之旅五(游戲界面文字處理詳解)
- Python:pygame游戲編程之旅六(游戲中的聲音處理)
- Python:pygame游戲編程之旅七(pygame基礎知識講解1)
- Python:編程“八榮八恥”之我見
- Python:腳本的幾種執行方式
- wxPython:簡單的wxPython程序
- wxPython:簡單的wxPython程序的另一種寫法
- wxPython:應用程序對象介紹
- wxPython:輸出重定向
- wxPython:關閉wxPython程序
- wxPython:Frame類介紹
- wxPython:面板Panel的使用
- wxPython:工具欄、狀態欄、菜單實現
- wxPython:消息對話框MessageDialog
- wxPython:文本對話框TextEntryDialog
- wxPython:列表選擇框SingleChoiceDialog
- wxPython:事件處理介紹一
- wxPython:事件處理介紹二
- wxPython: 簡單的繪圖例子
- wxPython:狀態欄介紹
- wxPython:菜單介紹
- wxPython:文件對話框wx.FileDialog
- wxPython:顏色選擇對話框wx.ColourDialog
- wxPython:布局管理器sizer介紹
- wxPython:啟動畫面SplashScreen介紹
- wxPython:繪畫按鈕BitmapButton介紹
- wxPython:進度條Gauge介紹
- Python: 發送新浪微博(使用oauth2)
- Python:讀取新浪微博收聽列表
- Python:DNS客戶端實現