国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

.NET程序如何啟動?

2019-11-14 16:10:40
字體:
來源:轉載
供稿:網友

.net程序如何啟動?

.NET Framework在Windows平臺頂部運行,這意味著.NET Framework必須使用 windows可以理解的技術來構建。首先,所有托管模塊和程序集文件都必須使用windows PE文件格式,而且要么是一個windows EXE文件,要么是一個DLL文件。

.net程序建立在CLR之上,因此.net程序的運行需要先加載正確的CLR環境。這樣我們把問題的關注點轉變為:

1、如何正確地加載CLR環境?

2、如何進入.net程序的Main函數?

為了更好地理解這個過程,我使用dumpbin.exe工具來解析PE文件格式并且轉儲出PE文件的內容。dumpbin.exe在visul studio中的Visul studio Tool的工具命令提示。我使用下面命令轉儲PE文件內容,

D:/PRogram Files (x86)/Microsoft Visual Studio 12.0/VC>dumpbin -all assembly>e:/dump.txt

轉儲部分內容如下:

OPTIONAL HEADER VALUES

             10B magic # (PE32)

           11.00 linker version

             A00 size of code

             800 size of initialized data

               0 size of uninitialized data

            29AE entry point (004029AE)

            2000 base of code

            4000 base of data

          400000 image base (00400000 to 00407FFF)

            2000 section alignment

             200 file alignment

            4.00 Operating system version

Entry point域表示PE文件的入口地址 值為Ox004029AE

要找出位置Ox004029AE所對應的代碼,需要查看PE映像的.text段,部分內容如下:

00402980: 00 00 00 00 00 00 00 00 90 29 00 00 00 00 00 00  .........)......

00402990: 00 00 5F 43 6F 72 45 78 65 4D 61 69 6E 00 6D 73  .._CorExeMain.ms

004029A0: 63 6F 72 65 65 2E 64 6C 6C 00 00 00 00 00 FF 25  coree.dll.....?%

004029B0: 00 20 40 00    

粗體字節對應于Entry Point,這些字節對應的機器指令為JMP 402000。要找到Ox402000指向的內容,我們可以查看PE文件的導入段,可以發現如下內容:

Section contains the following imports:

mscoree.dll

       402000 Import Address Table

       402988 Import Name Table

                0 time date stamp

                0 Index of first forwarder reference

                0 _CorExeMain

 

Ox402000指向的是mscoree.dll,這個庫包含一個導出函數_CorExeMain。_CorExeMain是mscoree.dll的一部分,這個函數也是加載.net程序集時第一個被調用的函數。mscoree.dll的主要作用是啟動CLR。mscoree.dll在啟動CLR時將執行一系列工作:

1、通過查看PE文件中的元數據,找出.NET程序集是由哪個版本的CLR構建的。

2、找出操作系統中正確版本CLR的路徑

3、加載并初始化CLR

在CLR被初始化之后,在PE映像的CLR頭中找到程序集的入口點(Main()),然后JIT開始編譯并執行入口點。

.NET程序集加載算法如下:

1、用戶執行一個.NET程序集

2、windows加載器查看AddressOfEntryPoint域,并找到PE映像文件的.text段。

3、位于AddressOfEntryPoint位置上的字節只是一個JMP指令,這個指令跳轉到mscoree.dll中的一個導入函數。

4、將執行控制轉移到mscoree.dll中的函數_CorExeMain中,這個函數將啟動CLR并且把執行控制轉移到程序集的入口點。

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 横峰县| 茶陵县| 布尔津县| 成都市| 德清县| 呼玛县| 张家港市| 岳西县| 青川县| 杭锦旗| 法库县| 班戈县| 长宁区| 江都市| 于都县| 莱西市| 佳木斯市| 乌拉特中旗| 克拉玛依市| 项城市| 肥西县| 玛纳斯县| 龙南县| 当雄县| 长治市| 四会市| 准格尔旗| 西昌市| 奈曼旗| 凉城县| 顺平县| 库尔勒市| 紫云| 合作市| 华亭县| 罗甸县| 射阳县| 仙居县| 连云港市| 仙居县| 芮城县|