程序理解中靜態(tài)分析與抽取技術(shù)的研究及實現(xiàn).pdf_第1頁
已閱讀1頁,還剩87頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、由于程序分析和理解的困難性,軟件系統(tǒng)特別是大型軟件系統(tǒng),其生存期往往長達(dá)數(shù)十年,多年的運行歷史,使得遺留軟件系統(tǒng)中包含了眾多知識,包括系統(tǒng)需求分析、設(shè)計決策、業(yè)務(wù)規(guī)則、維護(hù)及需求變更等。為了能夠充分利用這些遺留軟件資源,軟件系統(tǒng)的持續(xù)性演化變得十分重要。 然而,對這些系統(tǒng)常年的維護(hù)或演化異常困難,且成本開銷巨大。軟件維護(hù)已成為軟件工程界面臨的重要課題之一,能否準(zhǔn)確、迅速、全面地理解程序是決定維護(hù)工作成敗的關(guān)鍵。因此,程序理解研究

2、對軟件開發(fā)、管理和維護(hù)有著關(guān)鍵意義,特別是針對遺留軟件系統(tǒng)維護(hù)和演化具有重要的意義。 程序理解的目的在于獲得足夠的軟件系統(tǒng)信息,適用于人理解的形式展現(xiàn)出來,以輔助和促進(jìn)人對軟件的理解。這是一項非常耗費時間的過程,要自動實現(xiàn)對程序的分析、理解和表達(dá),首先要解決程序靜態(tài)分析和信息抽取關(guān)鍵技術(shù)。因為源程序分析的高效性、抽取信息的完整性和準(zhǔn)確性將直接影響到后續(xù)的程序理解系統(tǒng)的整個過程和性能,對軟件的維護(hù)工作或演化過程具有非常重要的作用和

3、意義。 論文通過深入的調(diào)研,在參閱國內(nèi)外大量文獻(xiàn)資料的基礎(chǔ)上,對程序理解、靜態(tài)分析技術(shù)和信息抽取機制進(jìn)行了較為系統(tǒng)的研究,所做主要工作包括: 1、對程序理解相關(guān)理論的研究:研究了有關(guān)程序理解的相關(guān)背景知識和技術(shù)現(xiàn)狀;對程序理解的意義、關(guān)鍵技術(shù)問題、存在困難以及設(shè)計模型進(jìn)行了較系統(tǒng)的研究。 2、對靜態(tài)分析技術(shù)進(jìn)行了研究,特別是對其中的預(yù)處理這一技術(shù)進(jìn)行了專題研究,針對如何處理源程序中的預(yù)處理分析、幾個編譯階段包含詞

4、法分析、具體預(yù)處理過程的實現(xiàn)等,提出了具體的實現(xiàn)模型和方案。 3、通過對目前典型抽取工具及靜態(tài)分析系統(tǒng)中詞法、語法分析工具的研究和比較,設(shè)計了靜態(tài)分析信息抽取系統(tǒng)的架構(gòu),設(shè)計和實現(xiàn)了語法和詞法分析器,重點實現(xiàn)了靜態(tài)信息抽取模塊。 4、通過分析傳統(tǒng)靜態(tài)分析抽取機制,研究了靜態(tài)分析抽取機制的優(yōu)化問題。此外,針對有些編譯系統(tǒng)的頭文件關(guān)系復(fù)雜、規(guī)模龐大的問題,論文對于如何提高這類文件的靜態(tài)分析抽取效率,如何快速、準(zhǔn)確地抽取信息進(jìn)

溫馨提示

  • 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論