我想可能有人對 VB的執行效能有點感冒
找了一下文章得到的答案是
VB 不能內嵌其他語言
需要透過他種語言以 DLL之類 形式引用
另一種方法就是本主題
在VB編譯時 攔截 "連結" 這個最終處理
(高階語言產生一個新的程式需要經過四個階段:前置處理、編譯、組譯、連結)
改寫 "組合語言" -> "重新組譯"成新的.OBJ後 "取代"之,再放行 "連結"
參考文章
如何和C或Assembly的程式鏈結
http://www.hosp.ncku.edu.tw/~cww/html/q00546.html
如何取得VB編譯後的LST檔
http://www.hosp.ncku.edu.tw/~cww/html/q00545.html
回到正題
如文中所言在專案下產生的 .lst
就是VB 翻譯 出來的 組合語言
或許有人會說 看都看不懂
只能說找重點看
看看能不能有簡化的地方
甚至改寫/加上 MMX/SSE 的應用
比如某一段程式
mov edx, DWORD PTR [esi]
xor eax, eax
push esi
mov DWORD PTR _unnamed_var1$[ebp], eax
mov DWORD PTR _unnamed_var1$[ebp], eax
mov DWORD PTR _unnamed_var1$[ebp], eax
mov DWORD PTR _unnamed_var1$[ebp], eax
mov DWORD PTR _unnamed_var1$[ebp], eax
mov DWORD PTR _unnamed_var1$[ebp], eax
call DWORD PTR [edx+780]
可以改成
mov edx, DWORD PTR [esi]
PXOR MM0,MM0
push esi
MOVQ QWORD PTR _unnamed_var1$[ebp], MM0
MOVQ QWORD PTR _unnamed_var1$[ebp], MM0
MOVQ QWORD PTR _unnamed_var1$[ebp], MM0
call DWORD PTR [edx+780]
※MOVQ解說
MOVQ mm,r/m64 或 MOVQ r.m64,mm
為轉移64位數據指令
將64位數據從 整數暫存器/記憶體 移到 MMX暫存器,和反向移動.
目標和來源 可為MMX暫存器,64位記憶體.
但MOVQ不能在 記憶體和記憶體之間 進行數據轉移.
,簡言之與 mov 沒什麼差別只是 暫存器多了個 MMX暫存器 可選擇
※PXOR解說
作用於 記憶體或MMX暫存器 的xor動作
MM0 是 MMX其中的一個 暫存器
是一個 64-bit 容量的暫存器
DWORD 等於 32 bit = 4Byte
QWORD 等於 64 bit = 8Byte
MMX Instructions
http://blog.csdn.net/ghj1976/archive...2/20/3270.aspx