版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、傳統(tǒng)的多線程程序引入了互斥鎖作為一種保護臨界區(qū)域的方式,然而,鎖的使用引入了新的錯誤,例如得到鎖卻沒有釋放。鎖的誤用導致的錯誤是非常常見且難以發(fā)現(xiàn)的。經(jīng)典的靜態(tài)代碼分析工具不用執(zhí)行源代碼程序就可以檢測軟件的錯誤或缺陷,所以被越來越多的采用。用該類技術(shù)實現(xiàn)的死鎖分析工具一般通過遍歷源代碼,根據(jù)程序語句更新程序當中所有鎖的狀態(tài),直到發(fā)現(xiàn)了導致死鎖的一個狀態(tài)。然而,由于缺少程序真正運行時的信息,靜態(tài)分析會變得不精確。例如,程序當中兩條相繼的l
2、ock指令是否會發(fā)生死鎖取決于它們是否是對同一把鎖進行操作,也就是這兩把鎖是否屬于同一個鎖集。在沒有準確信息的情況下,類似的工具只能做保守的估計,導致大量的誤報。
如果考慮采用傳統(tǒng)的指針別名分析方法來進行鎖集的識別,會存在兩個問題。一方面如果采用比較精確的上下文敏感流敏感的分析方法,分析效率比較差;另一個方面,如果采用比較簡單的上下文不敏感流不敏感的方法,則導致分析結(jié)果的不精確,原本屬于不同鎖集的鎖變量被判定為互為別名,使得后
3、續(xù)的靜態(tài)分析不能得到理想的結(jié)果。如何進行效率和精度的最大化是一個比較關(guān)鍵的問題。
本文通過基于指針別名分析技術(shù),針對鎖分析領(lǐng)域的典型問題,實現(xiàn)一種識別不同鎖集合的技術(shù)來輔助靜態(tài)分析。能夠在靜態(tài)分析工具查詢鎖的指向信息時給出精確的結(jié)果,該結(jié)果必須和流敏感上下文敏感指針分析的精確度相當。同時必須要解決分析的時間和空間效率問題。針對以上需求,本文提出一種利用粗粒度指針分析信息來指導后續(xù)分析的鎖集識別技術(shù),并且在此技術(shù)上開發(fā)了ELFI
4、工具。實驗表明,對于大型程序,ELFI區(qū)分出的鎖集數(shù)量是傳統(tǒng)的Andersen指針分析算法的3至6.6倍;并且經(jīng)過優(yōu)化的ELFI對于分析大程序平均有7.2倍的時間效率提升。
本文的主要貢獻有以下幾點:
(1)根據(jù)鎖變量在程序當中所占比例比較小這一事實,提出采用靜態(tài)切片技術(shù)對源程序根據(jù)鎖變量進行切片,以減少整個后續(xù)分析的工作量。對傳統(tǒng)的靜態(tài)切片方法進行改進,針對指針分析問題,利用粗粒度指向關(guān)系圖的拓撲結(jié)構(gòu)對相關(guān)指令進行
5、切片。
(2)把整個分析過程劃分為兩個獨立的分析階段,第一階段實現(xiàn)了輕量級的Andersen分析算法,并且實現(xiàn)了線下線上優(yōu)化算法、API概括、內(nèi)存存儲優(yōu)化提高分析性能。構(gòu)建粗粒度的指針指向關(guān)系圖,利用分析結(jié)果構(gòu)建數(shù)據(jù)流依賴圖作為細粒度的指針分析的基礎(chǔ)。初步得到的鎖集用來作為靜態(tài)切片的準則。
(3)在程序數(shù)據(jù)流依賴圖圖上,實現(xiàn)了上下文敏感、流敏感指針分析,采用二分決策圖來表示內(nèi)存指向關(guān)系,以及上下文信息。優(yōu)化數(shù)據(jù)流依賴
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 基于數(shù)據(jù)流的指針別名分析.pdf
- C-C++語言程序切片中的指針別名分析.pdf
- Java程序維護中基于別名分析的錯誤診斷技術(shù)與工具.pdf
- 基于二叉決策圖的別名分析研究.pdf
- 考慮指針別名的靜態(tài)分析技術(shù)研究.pdf
- 路徑敏感的跨過程別名分析的設(shè)計與實現(xiàn).pdf
- 基因集關(guān)聯(lián)分析工具.pdf
- ESP靜態(tài)鎖分析工具的Java實現(xiàn).pdf
- 基于自動化靜態(tài)分析工具對鎖使用模式的研究.pdf
- 馮姓男孩改名分析過程
- 基于matlab的共集放大電路分析工具的設(shè)計開題報告
- 基于類型分析和指針分析識別源程序中的設(shè)計模式.pdf
- 基于抽象解釋的帶指針算術(shù)程序的分析方法.pdf
- 包姓男寶寶取名分析過程
- 中國大學的世界排名分析
- 基于包含的上下文敏感指針分析技術(shù)研究.pdf
- 基于視頻分析的智能水表指針運動檢測
- 指針典型例題分析與解答
- 代理盲簽名分析及一種改進.pdf
- 多線程并發(fā)程序分析及別名算法研究.pdf
評論
0/150
提交評論