使用離線profile提升JavaScript程序的類(lèi)型可預(yù)測(cè)性.pdf_第1頁(yè)
已閱讀1頁(yè),還剩84頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

1、主流的JavaScript引擎(如V8)都使用了類(lèi)型特化技術(shù)來(lái)優(yōu)化程序性能,這種技術(shù)需要在運(yùn)行時(shí)預(yù)測(cè)各個(gè)程序點(diǎn)的變量的類(lèi)型集合。但JavaScript語(yǔ)言的動(dòng)態(tài)性會(huì)降低程序的類(lèi)型可預(yù)測(cè)性,使得引擎對(duì)類(lèi)型預(yù)測(cè)失?。▽?dǎo)致優(yōu)化代碼發(fā)生Deoptimization,即脫優(yōu)化)或者產(chǎn)生較差的預(yù)測(cè)結(jié)果(導(dǎo)致生成低質(zhì)量的代碼),對(duì)程序性能造成負(fù)面影響。
  本文通過(guò)分析Octane、Kraken和SunSpider測(cè)試集中的程序,發(fā)現(xiàn)了提高程序

2、類(lèi)型可預(yù)測(cè)性的策略,并據(jù)此設(shè)計(jì)實(shí)現(xiàn)了基于離線profile的優(yōu)化方案。本文的主要貢獻(xiàn)如下:
  (1)分析這些測(cè)試集中的應(yīng)用程序在運(yùn)行過(guò)程中的行為,提出通過(guò)提高類(lèi)型關(guān)聯(lián)度來(lái)提升類(lèi)型可預(yù)測(cè)性的策略。本文從48個(gè)應(yīng)用程序中總結(jié)出了6種會(huì)導(dǎo)致Deoptimization的模式,并分析了它們和引擎類(lèi)型系統(tǒng)的關(guān)聯(lián)。分析結(jié)果表明,可以通過(guò)增加類(lèi)型之間的聯(lián)系(稱(chēng)為類(lèi)型關(guān)聯(lián)度)來(lái)提升類(lèi)型可預(yù)測(cè)性。
  (2)根據(jù)引擎為每個(gè)屬性訪問(wèn)點(diǎn)的對(duì)象所

3、預(yù)測(cè)的類(lèi)型集合,分析每個(gè)集合中類(lèi)型之間的關(guān)聯(lián),提出通過(guò)調(diào)整對(duì)象布局來(lái)提高類(lèi)型關(guān)聯(lián)度的策略。通過(guò)分析預(yù)測(cè)的類(lèi)型集合大小大于1的屬性訪問(wèn)點(diǎn),以被訪問(wèn)屬性為橋梁,將這些類(lèi)型之間的關(guān)系分為4類(lèi),從而提出通過(guò)調(diào)整對(duì)象布局來(lái)增加類(lèi)型關(guān)聯(lián)度的策略。
  (3)提出了基于離線Profile的方案來(lái)調(diào)整對(duì)象布局,并在V8中進(jìn)行了實(shí)現(xiàn)。方案分成三個(gè)階段:插樁、Profiling和優(yōu)化。插樁階段會(huì)在程序中根據(jù)(2)中所提到的4種特點(diǎn),識(shí)別程序點(diǎn)并安插收

4、集變量類(lèi)型信息的代碼;Profiling階段執(zhí)行被插樁的代碼收集這些程序點(diǎn)中的類(lèi)型信息,并進(jìn)一步生成對(duì)屬性布局的調(diào)整方案(即屬性調(diào)整參照)。優(yōu)化階段會(huì)在啟動(dòng)時(shí)讀取屬性調(diào)整參照信息,再生成調(diào)整對(duì)象布局的優(yōu)化代碼以便增加類(lèi)型之間的關(guān)聯(lián)度,提高類(lèi)型可預(yù)測(cè)性。實(shí)驗(yàn)顯示,本文的方案在所有測(cè)試集上共減少22%的Deopfimization,而且運(yùn)行速度提升最高可達(dá)6%。
  本文提出了通過(guò)增加類(lèi)型關(guān)聯(lián)度來(lái)提高程序類(lèi)型可預(yù)測(cè)性的策略,并提出基于

溫馨提示

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

評(píng)論

0/150

提交評(píng)論