六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

用WinDbg探索CLR世界[1] - 安裝與環境設置

[摘要]一直以來,我對CLR的分析都是基于MSDN、.NET Framework SDK自帶文檔和Rotor項目提供的源代碼進行靜態分析,輔以自己寫的一些小例子或對Rotor的修修補補,來進行有限度的動態分...
一直以來,我對CLR的分析都是基于MSDN、.NET Framework SDK自帶文檔和Rotor項目提供的源代碼進行靜態分析,輔以自己寫的一些小例子或對Rotor的修修補補,來進行有限度的動態分析。雖然也用SoftIce跟蹤過某些核心函數的機制,但感覺實在是太痛苦了,呵呵。
最近偶然之間發現我的偶像John Robbins在MSDN的BugSlayer上發表的一篇文章<SOS: It's Not Just an ABBA Song Anymore>,才發現原來用WinDbg可以如此方便的動態分析CLR的運行機制。

首先,需要下載并安裝 Microsoft Debugging Tools [/url]。最好還能下載并安裝當前操作系統相應的Windows Symbol Packages。
然后,配置系統環境變量,讓搜索路徑指向系統.NET Framework的安裝目錄,既sos.dll所在目錄

set PATH=%PATH%;E:\WINDOWS\Microsoft.NET\Framework\v1.1.4322

啟動WinDbg之后,在File/Symbol Search Path選項中加入符號文件的安裝目錄,如

E:\WINDOWS\Symbols;E:\VS2003\SDK\v1.1\symbols

或者設置系統環境變量_NT_SYMBOL_PATH(需要重起WinDbg)

set _NT_SYMBOL_PATH=E:\WINDOWS\Symbols;E:\VS2003\SDK\v1.1\symbols

最后,在File菜單中,用Open Executable打開一個CLR程序或者用Attach to a process附加到一個正在運行的CLR程序上。

配置好WinDbg之后,如果打開一個新可執行程序,WinDbg會自動斷點到入口,則繼續運行再Break;如附加到進程則直接Break。
然后在最下方命令行上輸入系統命令 .load sos 命令載入外部擴展sos.dll。如果配置系統路徑正確則這里不會有任何反應,可以繼續用系統命令 .chain 查看當前載入的擴展。如下顯示則表示sos.dll成功載入。


以下為引用:

0:005> .chain
Extension DLL search Path:
E:\MS\PlatformSDK\Debugging Tools\winext;...;E:\WINDOWS\Microsoft.NET\Framework\v1.1.4322
Extension DLL chain:
sos: API 1.0.0, built Fri Feb 21 10:47:40 2003
[path: E:\WINDOWS\Microsoft.NET\Framework\v1.1.4322\sos.dll]
dbghelp: image 6.3.0005.1, API 6.0.6, built Fri Oct 24 02:11:02 2003
[path: E:\MS\PlatformSDK\Debugging Tools\dbghelp.dll]
ext: image 6.3.0005.1, API 1.0.0, built Fri Oct 24 09:06:45 2003
[path: E:\MS\PlatformSDK\Debugging Tools\winext\ext.dll]
exts: image 6.3.0005.1, API 1.0.0, built Fri Oct 24 02:10:39 2003
[path: E:\MS\PlatformSDK\Debugging Tools\WINXP\exts.dll]
uext: image 6.3.0005.1, API 1.0.0, built Fri Oct 24 02:10:54 2003
[path: E:\MS\PlatformSDK\Debugging Tools\winext\uext.dll]
ntsdexts: image 6.0.4044.0, API 1.0.0, built Wed Oct 22 02:13:21 2003
[path: E:\MS\PlatformSDK\Debugging Tools\WINXP\ntsdexts.dll]




在載入sos.dll之后,可以用 lm 命令看看當前有哪些模塊被載入內存,如


以下為引用:

0:005> lm
start end module name
...
77f30000 77ffa000 ntdll (export symbols) E:\WINDOWS\system32\ntdll.dll
79000000 79010000 ConfigWizards (deferred)
79040000 79085000 fusion (deferred)
79170000 79196000 mscoree (deferred)
791b0000 79412000 mscorwks (deferred)
...




對希望進行分析的模塊,可以用ld命令載入相應的調試符號文件(如果有的話,呵呵)。
如果符號文件搜索路徑配置正確的話,可以看到提示


以下為引用:

0:005> ld mscorjit
Symbols loaded for MSCORJIT




此時再用lm可以看到


以下為引用:

...
79430000 7947c000 MSCORJIT (pdb symbols) E:\VS2003\SDK\v1.1\symbols\mscorjit.pdb
...




如果符號文件搜索路徑配置錯誤,或者此模塊沒有調試符號文件,則會載入.dll的export表


以下為引用:

79170000 79196000 mscoree (export symbols) E:\WINDOWS\system32\mscoree.dll




或者干脆沒有符號


以下為引用:

79780000 79980000 mscorlib (no symbols)




完成以上的配置之后,就可以正式開始用WinDbg探索CLR的內部世界了,你可以敲個!SyncBlk,呵呵。




主站蜘蛛池模板: 日韩精品视频在线 | 中国女人一级做受免费视频 | 中文天堂在线最新2022更新 | 四虎影视国产884a精品亚洲 | 亚洲第一成年网 | 手机看片日韩日韩国产在线看 | 日韩毛片在线视频 | 午夜影皖| 天天看有黄有色大片 | 在线观看亚洲免费视频 | 亚洲成av人影院 | 日韩成人精品 | 欧美一及 | 亚洲国产乱码在线精品 | 亚洲欧美国产人成在线app | 日本片免费观看一区二区 | 啪啪福利视频 | 午夜91| 婷婷丁香在线视频 | 天天摸天天澡天天碰天天弄 | 午夜视频在线播放 | 欧美一区精品 | 在线视频h | 日韩三级伦理在线 | 一级做a爰片久久毛片免费 一级做a爰片久久毛片美女图片 | 青青在线国产视频 | 特黄一级黄色片 | 亚洲影视一区二区 | 日本在线看小视频网址 | 日韩精品视频免费网址 | 香蕉视频导航 | 青青草视频在线观看免费 | 日本成人h动漫 | 天天在线天天综合网色 | 欧美一级视 | 特黄特a级特别特级特毛片 特黄视频免费看 | 欧美亚洲免费久久久 | 新版天堂资源中文在线 | 色噜噜色偷偷男人的天堂 | 一级做性色a爰片久久毛片 一级做受视频免费是看美女 | 色综合啪啪 |