版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、單個(gè)軟件系統(tǒng)中以及若干個(gè)相似系統(tǒng)之間的代碼克隆給軟件維護(hù)增加了很大困難。因此,許多逆向工程方面的研究都關(guān)注于如何輔助進(jìn)行克隆代碼的發(fā)現(xiàn)和重構(gòu)?,F(xiàn)有的相關(guān)研究工作主要集中在克隆偵測上,而對克隆代碼的重構(gòu)方法研究較少。
本文首先針對運(yùn)用克隆偵測發(fā)現(xiàn)的相似代碼片斷,提出了一種基于抽象語法樹和靜態(tài)分析的代碼自動(dòng)重構(gòu)方法。該方法首先為克隆代碼分別構(gòu)造抽象語法樹,然后運(yùn)用語句差異度指標(biāo)建立起語法樹之間流程控制語句的對應(yīng)關(guān)系。在此基礎(chǔ)上
2、,該方法根據(jù)控制流程和基本語句塊兩個(gè)層次上的差異性分析,最終通過代碼可變點(diǎn)提取實(shí)現(xiàn)克隆代碼的自動(dòng)合并。
接著,本文在上述方法的基礎(chǔ)上,對面向?qū)ο筌浖到y(tǒng)的自動(dòng)重構(gòu)進(jìn)行了研究。本文提出了一種利用方法注釋和簽名等語義信息,以及方法體的語法層面的信息來尋找若干擁有共同父類的子類中的相同或者相似的方法。本文首先計(jì)算方法對的注釋和簽名整體相似度,作為第一輪篩選,本文只對那些注釋和簽名整體相似度超過某閾值的方法對進(jìn)行語法分析和對比,從
3、而計(jì)算出方法的整體相似度。然后,本文把方法的整體相似度當(dāng)作第二輪篩選的指標(biāo),將其作為是否進(jìn)行重構(gòu)的判據(jù)。最終,利用上述的可變性分析和提取的方法,將通過第二輪篩選的方法對合并為一個(gè)方法,這個(gè)方法就可以提升到父類中,從而實(shí)現(xiàn)重構(gòu)。
在本文方法的基礎(chǔ)上,我們針對Java代碼開發(fā)了克隆代碼重構(gòu)支持工具原型,并分別針對JDK包和一個(gè)業(yè)務(wù)系統(tǒng)中的克隆代碼進(jìn)行了自動(dòng)重構(gòu)實(shí)驗(yàn)。初步的實(shí)驗(yàn)結(jié)果表明,本文方法能夠準(zhǔn)確、有效地輔助開發(fā)者實(shí)現(xiàn)克隆
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 結(jié)合動(dòng)態(tài)測試和靜態(tài)分析的克隆代碼重構(gòu).pdf
- 基于抽象語法樹的重復(fù)代碼檢測.pdf
- 基于抽象語法樹和改進(jìn)粒子群算法的代碼同源性分析.pdf
- 基于抽象語法樹的程序代碼抄襲檢測技術(shù)研究.pdf
- 基于抽象語法樹的軟件語義分析方法研究.pdf
- 基于抽象語法樹的編程題自動(dòng)評分系統(tǒng)的研究與應(yīng)用.pdf
- 基于后綴語法樹的代碼抄襲檢測研究.pdf
- 基于GCC抽象語法樹文本的C源程序語義分析方法研究.pdf
- 克隆代碼的識別與重構(gòu).pdf
- 基于靜態(tài)分析的安全代碼檢測
- 基于靜態(tài)分析的安全代碼檢測
- 基于抽象語法樹的XQuery查詢語言實(shí)現(xiàn)技術(shù)研究.pdf
- 自動(dòng)化代碼靜態(tài)分析平臺的設(shè)計(jì)與實(shí)現(xiàn).pdf
- 基于靜態(tài)分析的代碼安全缺陷檢測系統(tǒng).pdf
- —基于Hirschman的相關(guān)理論和靜態(tài)博弈模型.pdf
- Web應(yīng)用中基于樹的克隆代碼檢測方法的研究.pdf
- 基于TTCN-3抽象語法樹的可執(zhí)行測試套的生成研究.pdf
- 基于K-最近鄰的C克隆代碼重構(gòu)方法研究.pdf
- 可重構(gòu)克隆代碼的過程提取方法研究.pdf
- 基于腳本代碼靜態(tài)分析的網(wǎng)頁掛馬檢測.pdf
評論
0/150
提交評論