Lua虛擬機的機制分析.pdf_第1頁
已閱讀1頁,還剩86頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、自Lua從巴西天主教大學被開發(fā)出來已經(jīng)有20多年。隨著計算機應(yīng)用技術(shù)的飛速發(fā)展和高級腳本語言的不斷完善,Lua能很方便地嵌入到應(yīng)用程序并為它們提供靈活的擴展和定制功能。與其它同類的高級解釋型腳本語言相比,Lua有著兩點非常重要的特性:簡潔、高效。多數(shù)實驗表明,Lua在程序執(zhí)行效率上要比大部分的腳本語言(如Python、Perl等)高。另外Lua還提供非常豐富和實用的功能,比如函數(shù)式編程(所有的函數(shù)都是第一類值)、協(xié)同程序、自動內(nèi)存管理等

2、。由于Lua是用C編寫而成,它與C/C++能非常方便的交互,而所有這些特性都歸功于它有一個精簡的、巧妙的、高效的Lua虛擬機的設(shè)計。
  Lua在相當長一段時間內(nèi)都使用堆棧式的虛擬機,而從5.0版本后才改用寄存器式的虛擬機。基于寄存器的虛擬機減少了指令總數(shù)和指令執(zhí)行時堆棧調(diào)整的開銷因此執(zhí)行效率得到提高。虛擬機的效率除了與指令操作數(shù)存儲結(jié)構(gòu)有關(guān)外還與編譯和解釋過程相關(guān)。解釋性源程序一般要經(jīng)過編譯成字節(jié)碼階段,然后由解釋器逐條解釋和執(zhí)

3、行字節(jié)碼。解釋器中執(zhí)行框架的設(shè)計直接影響了解釋效率,Lua采用了一種最簡單的執(zhí)行框架設(shè)計方式(switch-case),由于它指令數(shù)較少,因此也獲得了較好的執(zhí)行效率。較新版本的Python虛擬機在采用了較好的指令分派方式后也獲得了效率提升,而其它的采用效率更高方案的虛擬機必然也在設(shè)計上更復雜或占用更多內(nèi)存。除此之外,垃圾回收(GC)算法也在一定程度上影響了虛擬機的效率,雖然Lua GC經(jīng)過了若干技術(shù)的優(yōu)化—比如分代的、增量式的垃圾回收—

4、有著與其他GC機制相差不大的效率。但與其它虛擬機GC機制相比,LuaGC主體仍使用較為古老的標記-清除算法,該算法在標記和回收過程上都比較耗時而且在內(nèi)存利用率(內(nèi)存碎片的產(chǎn)生)方面有劣勢,因而在性能上也略低于許多其它的虛擬機,Lua GC機制仍需要改善。
  本文首先簡單的介紹了Lua的語言特性;然后深入分析了Lua虛擬機的實現(xiàn),特別對Lua的編譯過程、線程執(zhí)行、函數(shù)調(diào)用和GC過程進行了深度探究;其次將Lua虛擬機中的關(guān)鍵技術(shù)與P

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論