NET編譯時都做了一些什麼 (轉)

amyz發表於2007-08-15
NET編譯時都做了一些什麼 (轉)[@more@]

在新聞組和列表裡有大量關於一個的設計編譯(design-time or
run-time)和執行原理 (-specific binary or pseudo-code)的疑問。

這裡是一個簡單的回答:當你編譯一個應用程式或任何一種CLS(Commmon
Language Specification)相容的語言時,它將首先被編譯成一種稱為IL
(Intermediate Language)的虛擬碼(pseudo-code)。在這個應用程式第一次
被執行的時候,這種IL程式碼將被編譯成機器程式碼,用於。也就是說從
到得到執行結果,進行了兩次編譯。事實上,只有那些被真正使用的程式碼
才會被進行第二次編譯。下面揭示開發過程中被隱藏起來的細節:

1) 你用C#開發一些程式
2) 用C#或CLS相容的編譯器編譯成EXE
3) 編譯器將生成的IL程式碼和附加資訊(manifest)放入擁有一個標準PE頭的
可執行的只讀部分。
4) 編譯器在建立這個可執行檔案時匯入(import)一個名為_CorExeMain的函式。
這個函式是.NET EE(execution engine)--.NET執行期引擎的入口函式。
5) 當執行這個Win32可執行檔案時,因為其主要是依賴於DLL的PE檔案,操作系
統將會位於MrEE.DLL中的_CorExeMain函式。
6) 操作透過PE檔案裡的進入點,呼叫MSCorEE.DLL。並能保證在裡
可以有很多程式同時執行。
7) 因為不能執行.NET IL程式碼,EXE裡的進入點只是簡單的中介,它將
指示作業系統呼叫_CorExeMain函式。
8) 隨後_CorExeMain函式開始解釋位於PE檔案中的IL程式碼。
9) 因為IL是不能被直接執行的, EE使用稱為JITter (Just In Time compiler)
的即時編譯器將IL程式碼編譯成本地CPU機器程式碼用於執行。這一即時編譯過程
只在第一次執行的時候進行。


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10752019/viewspace-958763/,如需轉載,請註明出處,否則將追究法律責任。

相關文章