![]() |
動態組合的程式技巧
不知有無支援 動態組合 這種程式語言 或 語法範例
比如 一個程式有 A、B、C 等 副程式 傳統程式設計之 主程式 如下 語法:
For i = 0 to n 動態組合之 主程式 如下 語法:
ret = GetSUBAddress(Z) SubAdd 根據 函式的位址 負責將 A、B、C 串接成 Z Z 是動態組合副程式 其作用是可省略每次的 If x.check = 1 then If y.check = 1 then If z.check = 1 then 當 n 是一筆很大的數值時,將可節省下相當的運算時間 當然前提是 Z 不能有多餘的判讀 否則就失去其意義 ====================== 用組合語言好像可以改寫的出來 不過...太麻煩了 自己可以想到的是 根據 A、B、C 大小 及 If x.check = 1 then If y.check = 1 then If z.check = 1 then 結果 宣告一個空白的記憶體 再將 A、B、C 稍做修改的內容 傾印入內 做成一個全新的 可執行副程式 只是中間好像不是這麼單純的樣子... |
這程式碼應該不是C或C++的吧
有的話可給一下嘛.....不然我不能應用XD~感謝^^ |
引用:
這個主題是問題與討論 個人也想知道有無可能與實作範例... 個人偏好用VB、PB寫 那個程式碼只是一種表達式,並非哪一種程式(教學或考試時 方便使用) 剛剛找到一個程式碼 好像稍作應用就可以完成 哪天寫出來再分享 當然也希望大家參與討論 |
找到一個折衷的寫法
(雖沒有達到理想境界,但可以接受) c++ 可能需用到 函式指標 觀念 個人大部分是寫 VB 會用到的WinAPI Public Declare Function CallWindowProc Lib "user32" Alias "CallWindowProcA" (ByVal lpPrevWndFunc As Long, ByVal hwnd As Long, ByVal Msg As Long, ByVal wParam As Long, ByVal lParam As Long) As Long 原理是 得到各函式記憶體位址 接著經過一次的判讀決定用哪一個函式 而迴圈統一固定使用 CallWindowProc 經過測試 的確有省略時間 用 OllyDbg 可發現 CallWindowProc 會 push 五個參數 而 If 有 60% 的可能性會被編譯器轉成 虛擬機器判讀語法 如此就會超過 CallWindowProc 總共 6條 組合語言指令 (聽不懂就當本人在自說自話吧~畢竟花了兩個星期研究,有點一言難盡) 至於實作 已在個人 新版 檔案清單列表機 使用到 而範例... 如有版友有興趣 方 打包貼出來分享 :on_79: |
所有時間均為台北時間。現在的時間是 10:20 PM。 |
Powered by vBulletin® 版本 3.6.8
版權所有 ©2000 - 2025, Jelsoft Enterprises Ltd.
『服務條款』
* 有問題不知道該怎麼解決嗎?請聯絡本站的系統管理員 *