淺談.NET CLR的基礎(chǔ)知識(shí)
今天筆者溫故了.NET CLR的相關(guān)知識(shí),順便拿出來(lái)和大家分享一下,筆者所講的.NET CLR很基礎(chǔ),希望能給你帶來(lái)幫助。
大家都知道.NET是支持所謂的多語(yǔ)言的,但其實(shí).NET只有一種語(yǔ)言,就是MSIL,其它所有的語(yǔ)言,按照今天培訓(xùn)課上講的,就是MSIL的一種子語(yǔ)言。MSIL看起來(lái)類似一種匯編語(yǔ)言,想當(dāng)初,用MSIL做一個(gè)虛擬機(jī),做的是云里來(lái),霧里去的,對(duì)匯編還是怕的很。
在很多時(shí)候,MSIL都被當(dāng)成一種基于棧的OO形式的匯編語(yǔ)言。而這種語(yǔ)言被.NET CLR所編譯,轉(zhuǎn)換成本地執(zhí)行文件。在這里要注明的是,MSIL并不像其它的匯編語(yǔ)言,它所包含匯編指令不是應(yīng)用于一臺(tái)真正的機(jī)器上,而一種抽象的機(jī)器上,也因?yàn)榇?,基于MSIL的程序可以應(yīng)用于不同的機(jī)器上,這也是MSIL的特點(diǎn)之一。
而在一臺(tái)機(jī)器上,MSIL代碼是不能被直接編譯的,而是必須首先經(jīng)過(guò)JIT轉(zhuǎn)換成本地代碼(native code)。
那么MSIL究竟能做什么呢?呵呵,即然做為.NET CLR的“唯一”的一種語(yǔ)言,凡是你在其它語(yǔ)言里能做到的,就是MSIL所做的。那在編譯一個(gè).NET CLR文件中,MSIL具體在何時(shí)何地扮演何種角色呢?(很想畫個(gè)圖,可是不知道怎么在CNBlog中實(shí)現(xiàn),好像以前直接從word里可以直接copy,現(xiàn)在不行了) 大概描述一下編譯的流程,大家應(yīng)該就能明白了。
按照傳統(tǒng)的編譯流程,是將source code 編譯成object code,再將object與一個(gè)library連接起來(lái)編譯成binary文件,然后執(zhí)行binary文件。而隨后推出了Dynamic link Compilation, 即動(dòng)態(tài)編譯,其指的是將source code編譯成一個(gè)object code,但是其在編譯時(shí)不連接libary文件,而是在運(yùn)行binary文件時(shí),動(dòng)態(tài)連接library 文件。
那可能有人就問(wèn),library文件是什么?它其實(shí)包含的就是metadata,元數(shù)據(jù)。而在.NET CLR中采用的是所謂的JIT Compilation, (Just In Time Compilation),它的實(shí)現(xiàn)原理與動(dòng)態(tài)編譯類似,將source code轉(zhuǎn)換成MSIL,再利用JIT將MSIL轉(zhuǎn)換成本地代碼,在運(yùn)行時(shí),讀取Assembly中的元數(shù)據(jù)進(jìn)行相關(guān)操作。
大概的.NET CLR流程就是這樣了,不多說(shuō)了,這個(gè)要說(shuō)下去,就該談?wù)刴etadata, 還有一些編譯過(guò)程的細(xì)節(jié),比如說(shuō)JIT Engine, BackPatch, JMI Thunk等一系列的編譯機(jī)制。
【編輯推薦】