線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:1963
推到 Plurk!
推到 Facebook!

是否有工具可以看 User32.dll 內 API 被叫用的次數?

答題得分者是:wameng
dllee
站務副站長


發表:321
回覆:2519
積分:1711
註冊:2002-04-15

發送簡訊給我
#1 引用回覆 回覆 發表時間:2007-08-10 08:25:13 IP:59.105.xxx.xxx 訂閱
主要我的問題如   [問題] 那些動作會增加 User Handle(User 物件)? 所述。
harpist 所述,可能是在程式中有使用資源不釋放或是其他問題,但因為有部分
是使用別人的元件,沒有原始碼,而發生問題時,如果可以知道是那個 API 被叫
用多次而使 User Handle/Object 增加,會比較容易找出是那裏的問題。
所以才想,是否有這樣一個工具,可以看 API 被叫用的次數呢?
------
http://www.ViewMove.com
wameng
版主


發表:31
回覆:1336
積分:1188
註冊:2004-09-16

發送簡訊給我
#2 引用回覆 回覆 發表時間:2007-08-10 11:16:04 IP:61.31.xxx.xxx 訂閱
就是沒用 CloseHandle  。可用Memproof 檢查 Handle 使用次數。
詳細檢查程式碼。有用 Handle 最後都要關閉。
dllee
站務副站長


發表:321
回覆:2519
積分:1711
註冊:2002-04-15

發送簡訊給我
#3 引用回覆 回覆 發表時間:2007-08-10 13:08:34 IP:220.134.xxx.xxx 訂閱
感謝 wameng 大大的回覆。
MemProof 還真的是不錯耶,可惜,我的 Project 太大了無法這樣除錯,
因為載入時間就要 9 分半鐘,進入系統操作有些 Lag...

程式載入完成 MemProof 的圖:


開啟 Process Explorer 作比對:


USER 733 但 MemProof 內的 User 加起來也沒那麼多呀?

MemProof 的下一代 AQTime 不知道有沒有改進效能,不然,幾乎不可能線上除錯,
又 MemProof 不能用 Attach 的方式,只能用 Open 的方式開檔。

===================引 用 wameng 文 章===================
就是沒用 CloseHandle 。可用Memproof 檢查 Handle 使用次數。
詳細檢查程式碼。有用 Handle 最後都要關閉。
------
http://www.ViewMove.com
harpist
資深會員


發表:3
回覆:251
積分:430
註冊:2002-10-03

發送簡訊給我
#4 引用回覆 回覆 發表時間:2007-08-10 15:38:01 IP:59.104.xxx.xxx 未訂閱
比較苦力的方式可以調用 GetGuiResources 去慢慢找
------
~§~迷時師渡,悟了自渡~§~
dllee
站務副站長


發表:321
回覆:2519
積分:1711
註冊:2002-04-15

發送簡訊給我
#5 引用回覆 回覆 發表時間:2007-08-10 16:45:14 IP:220.134.xxx.xxx 訂閱
感謝 harpist 的回覆。
如果全部都是自己寫的就比較好辦,但使用別人的元件沒有原始碼,
又很機車的不允許在 IDE 內運行,再加上它會開多執行緒處理通訊
資料。這樣使用 GetGuiResources 在某函式進出不同時,有可能是
因其他執行緒所產生的,這樣就無法使用此法判斷了。

感謝 wameng 大大介紹的工具,我已找出一些問題 API 了,

TimeStamp 10:45:56 10:46:02 10:46:08 10:46:16 11:00:14
CreateWindowExA 656 656 656 656 12486
DefWindowProcA 35397 35446 36566 36590 83537
DestroyWindow 228 228 228 228 228
GetClassInfoA 861 861 861 861 12691
GetClassLongW 1879 1879 1879 1879 11083
GetWindowLongW 45027 45062 45944 45957 65142
SetPropW 2486 2486 2486 2486 11690
SetWindowLongA 1091 1091 1091 1091 12921

10:45:56 程式啟動一段時間
10:46:02
10:46:08 對方連線並開始送資料
10:46:16 到目前都還是正常
11:00:14 User Objects 已是爆掉的 10,000

由以上 API 叫用次數發現,有 CreateWindowExA 但沒有 DestroyWindow 所以
User Object 一直成長。而 CreateWindowEx 在 BCB/Delphi 的系統一定是包含
VCLxx.bpl 很少人會直接叫用它的,在 CreateWindow 同時,會 GetClassInfo,
GetClassLong, GetWindowLong, SetProp, SetWindowLong 的函式,就是我
的下一個目標了。我大約已猜到是那個 VCLxx.bpl 的函式被異常叫用了,同時,
此函式也是使用的元件它有使用的函式

===================引 用 harpist 文 章===================
比較苦力的方式可以調用 GetGuiResources 去慢慢找
------
http://www.ViewMove.com
系統時間:2024-03-29 12:42:31
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!