專利名稱:一種基于代碼變更的軟件模型同步方法
技術領域:
本發(fā)明涉及對過期的軟件模型與新代碼進行同步的方法,屬于軟件工程、模型驅動工程交叉技術領域。
背景技術:
模型驅動工程是以模型為主要產品,試圖通過建立模型來明確軟件開發(fā)的內容,是近年來軟件工程發(fā)展的重要課題。模型用建模語言來表示,能夠描述軟件卻高于軟件,是一種描述設計、指導軟件開發(fā)的中間產物。標準的軟件開發(fā)流程包括需求分析、模型設計、代碼編寫以及測試部署這些步驟。其中模型設計不但承接了需求分析中的各種要素,而且還是后續(xù)編寫代碼軟件測試等活動的基準,在整個開發(fā)流程中至關重要。軟件開發(fā)過程中,模型作為設計思路和業(yè)務邏輯的抽象,能夠指導開發(fā)人員之間的交流以及代碼的開發(fā)和軟件的交付。開發(fā)人員需要理解模型的含義,然后用程序設計語言表達出模型中的種種信息,模型中的要求和思路都會在代碼中得到體現(xiàn),最終遞交的軟件和模型是一致的。在證明軟件的正確性時,也是通過它和模型的對應關系入手的,能夠解決問題的軟件系統(tǒng)往往非常復雜,而其模型是某種層次上的抽象,因此在企業(yè)的實際開發(fā)和測試中,可以通過證明模型的正確性以及模型與軟件系統(tǒng)的對應關系來證明軟件的正確性。軟件開發(fā)完成后,并不是一成不變的。在實際的使用和生產環(huán)境中,軟件往往會因為多種原因,如使用場景變化、用戶要求、性能優(yōu)化、錯誤排除,由開發(fā)人員進行維護。這個維護過程中,軟件會進行不斷演化,代碼會經過諸多修改而變成新的東西,而模型可能會被忽視。多個版本之后代碼與最初的代碼有了很大的變化,與最初的模型也無法對應,這時如果需要模型來完成相關工作,就會遇到模型與代碼的不一致問題。這種不一致問題會導致模型過期,那么與模型相關的一系列軟件開發(fā)行為就無法正常進行。在實際開發(fā)環(huán)境中,往往由一組開發(fā)人員進行協(xié)作完成代碼和相關的開發(fā)任務,代碼通過多次迭代開發(fā)最終成型。在整個開發(fā)過程中,代碼由代碼管理系統(tǒng)來進行管理,提供版本控制、沖突檢查、代碼分發(fā)、子版本管理、變更檢測等多種功能。每個代碼單元(比如源代碼文件)從無到有的各個狀態(tài)都由這個系統(tǒng)統(tǒng)一管理,如果需要源代碼文件的歷史版本、演化軌跡,都可以向代碼管理系統(tǒng)發(fā)出請求。
發(fā)明內容
技術問題:本發(fā)明的目的是處理代碼演化過程中軟件模型同步方法,以舊代碼以及舊模型為基準,通過分析新代碼與舊代碼的變更內容,并自動識別舊代碼和舊模型之間的關系,對舊模型進行修改和更新,得到與新代碼相匹配的新模型。技術方案:本發(fā)明所述基于代碼變更的軟件模型同步方法采用代碼變更分析技術來比較代碼之間的差別,利用代碼檢索技術自動將為軟件模型和代碼建立聯(lián)系,通過軟件模型所適用的規(guī)則集,逐個處理代碼變更,并對模型進行自動或半自動更新。本發(fā)明所述軟件模型是對軟件實體進行簡化,用適當?shù)淖儸F(xiàn)形式或規(guī)則把它的主要特征描述出來。本發(fā)明所述軟件模型所適用的規(guī)則集包括一系列規(guī)則,每一個規(guī)則給出模型中的元素和標準代碼中的元素關系,該規(guī)則和標準代碼由開發(fā)人員預先定義。步驟1、代碼變更分析從有變化的代碼中,將非實質變更、非本質變更、非相關變更的代碼過濾出去,獲得軟件模型相關的變更代碼,所述非實質變更是指在不斷演化過程中,開發(fā)人員可能會引入一些格式的調整,比如空白字符、空行,這些變更只是改變代碼文件的存儲內容,沒有改變根據(jù)代碼所得到的軟件行為和結構,所述非本質變更是指在代碼語法和語義約束下,程序代碼內容改變,但根據(jù)代碼所得到的軟件在行為和結構上保持不變,所述非相關變更是指變更發(fā)生在與模型無關的代碼片段,但不在模型所關注的范圍內;步驟2、模型代碼匹配給定軟件模型,根據(jù)模型的類型和元素的名稱,對模型與軟件模型相關的變更代碼進行匹配,建立模型中的元素與代碼中的元素之間的對應關系,具體匹配過程如下:·
步驟2.1:讀入軟件模型,讀入軟件模型所適用的規(guī)則集;步驟2.2:讀入軟件模型相關的變更代碼;步驟2.3:確定模型中需要對應的元素,逐個根據(jù)模型所適用的規(guī)則在軟件模型相關的變更代碼中進行搜索,找到可能與之相聯(lián)系的代碼片段,并給出可信度,根據(jù)預設定的可信度閾值決定立即匹配或是交由開發(fā)人員確認;步驟2.4:將所獲得的模型中的元素與代碼中的元素之間的對應關系信息加入代碼庫中;步驟3、代碼變更處理將得到的代碼變更信息、模型中的元素與代碼中的元素之間的對應關系翻譯為更新操作,產生新模型,具有步驟為:步驟3.1:根據(jù)軟件模型所適用的規(guī)則、模型中的元素與代碼中的元素之間的對應關系、已修改的變更代碼,修改對應的模型元素;步驟3.2:根據(jù)軟件模型所適用的規(guī)則、模型中的元素與代碼中的元素之間的對應關系、已刪除的變更代碼,移除對應的模型元素;步驟3.3:根據(jù)軟件模型所適用的規(guī)則、模型中的元素與代碼中的元素之間的對應關系、已新增的變更代碼,判斷是否需要在模型中新增新的元素,如果是,則在模型中新增新的元素。步驟I中所述非實質變更是指在不斷演化過程中,開發(fā)人員可能會引入一些格式的調整,這些變更沒有改變根據(jù)代碼所得到的軟件行為和結構。步驟I中所述非本質變更是指在語法和語義約束下,代碼內容改變,但根據(jù)代碼所得到的軟件在行為和結構上保持不變。
步驟I中所述非相關變更是指變更發(fā)生在與模型無關的代碼片段,但不在模型所關注的范圍內。有益效果:本發(fā)明所述的基于代碼變更的軟件模型同步方法中,相關功能可以集成在代碼版本管理系統(tǒng)中,能夠自動判斷代碼的差異,確定如何修改模型,對于模棱兩可的情況會向開發(fā)人員請求人工干預。具體說來,本發(fā)明所述的方法具有如下有益效果:(I)在本發(fā)明所述的基于代碼變更的軟件模型同步方法中,代碼的差異是通過自動分析出來的,并且能夠根據(jù)預先設定的規(guī)則過濾不相關的變更差異,減輕開發(fā)人員的負擔。(2)在本發(fā)明所述的基于代碼變更的軟件模型同步方法中,模型與代碼比較采用啟發(fā)式模糊匹配,對于不確定的情況會經過人工確認,既保證了正確性又減輕工作量。(3)在本發(fā)明所述的基于代碼變更的軟件模型同步方法中,模型在修改之后會與代碼進行校驗,以確保模型與代碼的一致性。(4)在本發(fā)明所述的基于代碼變更的軟件模型同步方法中,模型與代碼的定義規(guī)則比較靈活,等夠適應不同的復雜系統(tǒng)以及用戶需求的變化。
圖1是基于代碼變更的軟件模型同步方法具體實施流程示意圖。圖2是代碼變更示意圖。圖3是代碼變更分析流程示意圖。圖4是代碼與模型對應示意圖。圖5是開發(fā)人員在方法中所扮演角色的示意圖。
具體實施例方式本發(fā)明所述的基于代碼變更的軟件模型同步方法具體實施中,首先需要現(xiàn)有的軟件模型以及與軟件模型相對應的軟件代碼,可以通過版本控制系統(tǒng)管理同一代碼單元的不同版本。本發(fā)明根據(jù)規(guī)則集解析不同的軟件模型,可以采用代碼檢索技術,結合啟發(fā)式信息,將模型中的元素與代碼中的元素之間建立起對應的對應關系。對不同版本的代碼進行比較,過濾出較為重要的變更,根據(jù)軟件模型所適用的規(guī)則集,決定如何修改、刪除和新增模型,并進行最終更新模型。本發(fā)明所述的基于代碼變更的軟件模型同步方法具體實施流程如圖1所示。下面對附圖本發(fā)明的某些實施例作更詳細的描述。1、代碼變更分析本發(fā)明所述的基于代碼變更的軟件模型同步方法具體實施中,需要對新舊兩個版本的代碼進行分析,因為其中的差別就是造成了舊版軟件模型與新版代碼不一致的因素。在具體實施中,需要準確地弄清楚到底應該將那些變更反映在原來的軟件模型中。圖2是代碼變更示意圖,原始代碼(圖2左)與變更代碼(圖2右)之間進行存在差異,在具體實施中,可以定制編譯器,處理代碼的新舊版本,生成特定的代碼表示,以過濾一些不需要關心的代碼變更,如圖3所示。這些不需要關心的代碼變更`主要包括非實質代碼變更、非本質代碼變更、非相關代碼變更等三種。
(I)非實質代碼變更代碼在不斷演化過程中,開發(fā)人員可能會引入一些格式的調整,比如空白字符、空行,這些變更固然改變了代碼文件的存儲內容,但是并不能算作真正的代碼變更,因為根據(jù)代碼所得到的軟件無論在行為上還是結構上都保持不變,說明這些代碼變更沒有造成實質上的變化。在對舊版模型進行更新的時候,完全不必考慮此類變更,因此需要在具體實施中將這種變更過濾出去。(2)非本質代碼變更代碼都是用編程語言來寫的,遵照一定的語法和語義。在這種約束下,除了非實質代碼變更,還有一些雖然改變了程序的代碼內容,但根據(jù)代碼所得到的軟件在行為和結構上仍然保持不變。這是因為程序語言在設計過程中,為了使用方便,往往會為同一種含義加入多種表達方式,比如通常的程序設計語言對于循環(huán)會有while組合句和for組合句這兩種。那么如果代碼中的while完全可能被改成for語句,而代碼在本質上并沒有語義變化。這種變更也不會影響模型的更新,所以在具體實施中也應該被過濾。
(3)非相關代碼變更代碼是根據(jù)模型編寫的,有些代碼直接反應了模型中某個組件的語義,有些代碼則是對模型更進一步的細化和對平臺的適應。如果代碼變更發(fā)生在與模型無關的代碼片段,那么這些變更雖然在本質上改變了軟件的行為或者結構,但其具體變更并不在模型所關注的范圍內,因此這一類變更在具體實施中也需要排除在外。代碼變更分析是對代碼進行解析并進行比較的過程,在具體實施時需要手動修改編譯器的前段,加入自定義的處理規(guī)則,以從有變化的代碼中將非實質變更、非本質變更、非相關變更的代碼過濾出去,獲得軟件模型相關的變更代碼。2、模型代碼匹配本發(fā)明所述的基于代碼變更的軟件模型同步方法具體實施中,模型與代碼之間有某種對應關系,將模型分成最簡單的組件,如圖4所示,以統(tǒng)一建模語言中的活動圖為例說明,則分為節(jié)點和邊,其中節(jié)點分為很多細類,邊也分為帶條件和無條件兩類,具體實施步驟如下:步驟1:讀入活動圖模型,讀入模型所適用的規(guī)則集;步驟2:讀入活動圖模型相關的變更代碼;步驟3:確定活動圖模型中需要對應的節(jié)點和邊等元素,逐個根據(jù)規(guī)則在代碼中進行搜索,找到可能與之相聯(lián)系的代碼片段,并給出可信度,根據(jù)預設定的可信度閾值決定立即匹配或是交由開發(fā)人員確認。步驟4:將所獲得的對應信息加入代碼庫中。3、代碼變更處理代碼變更得到之后,需要根據(jù)這些變更以及模型代碼之間的對應關系,決定如何修改、刪除和新增模型元素。本發(fā)明所述的基于代碼變更的軟件模型同步方法具體實施中,有些不能確定的情況,如匹配情況,修改確認,需要人工干預,如圖5所示。
權利要求
1.一種基于代碼變更的軟件模型同步方法,其特征在于該方法所包含的步驟為: 步驟1、代碼變更分析 從有變化的代碼中,將非實質變更、非本質變更、非相關變更的代碼過濾出去,獲得軟件模型相關的變更代碼, 所述非實質變更是指在不斷演化過程中,開發(fā)人員可能會引入一些格式的調整,比如空白字符、空行,這些變更只是改變代碼文件的存儲內容,沒有改變根據(jù)代碼所得到的軟件行為和結構, 所述非本質變更是指在代碼語法和語義約束下,程序代碼內容改變,但根據(jù)代碼所得到的軟件在行為和結構上保持不變, 所述非相關變更是指變更發(fā)生在與模型無關的代碼片段,但不在模型所關注的范圍內; 步驟2、模型代碼匹配 給定軟件模型,根據(jù)模型的類型和元素的名稱,對模型與軟件模型相關的變更代碼進行匹配,建立模型中的元素與代碼中的元素之間的對應關系,具體匹配過程如下: 步驟2.1:讀入軟件模型,讀入軟件模型所適用的規(guī)則集; 步驟2.2:讀入軟件模型相關的變更代碼; 步驟2.3:確定模型中需要對應的元素,逐個根據(jù)模型所適用的規(guī)則在軟件模型相關的變更代碼中進行搜索,找到可能與之相聯(lián)系的代碼片段,并給出可信度,根據(jù)預設定的可信度閾值決定立即匹配 或是交由開發(fā)人員確認; 步驟2.4:將所獲得的模型中的元素與代碼中的元素之間的對應關系信息加入代碼庫中; 步驟3、代碼變更處理 將得到的代碼變更信息、模型中的元素與代碼中的元素之間的對應關系翻譯為更新操作,產生新模型,具有步驟為: 步驟3.1:根據(jù)軟件模型所適用的規(guī)則、模型中的元素與代碼中的元素之間的對應關系、已修改的變更代碼,修改對應的模型元素; 步驟3.2:根據(jù)軟件模型所適用的規(guī)則、模型中的元素與代碼中的元素之間的對應關系、已刪除的變更代碼,移除對應的模型元素; 步驟3.3:根據(jù)軟件模型所適用的規(guī)則、模型中的元素與代碼中的元素之間的對應關系、已新增的變更代碼,判斷是否需要在模型中新增新的元素,如果是,則在模型中新增新的元素。
2.根據(jù)權利要求1所述的一種基于代碼變更的軟件模型同步方法,其特征在于步驟I中所述非實質變更是指在不斷演化過程中,引入一些格式的調整,這些變更沒有改變根據(jù)代碼所得到的軟件行為和結構。
3.根據(jù)權利要求1所述的一種基于代碼變更的軟件模型同步方法,其特征在于步驟I中所述非本質變更是指在語法和語義約束下,代碼內容改變,但根據(jù)代碼所得到的軟件在行為和結構上保持不變。
4.根據(jù)權利要求1所述的一種基于代碼變更的軟件模型同步方法,其特征在于步驟I中所述非相關變更是指變更發(fā)生在與模型無關的代碼片段,但不在模型所關注的范圍內。
全文摘要
本發(fā)明提出的一種基于代碼變更的軟件模型同步方法,該方法從有變化的代碼中將非實質變更、非本質變更、非相關變更的代碼過濾出去,獲得軟件模型相關的變更代碼,對軟件模型與其相關的變更代碼進行匹配,建立模型中的元素與代碼中的元素之間的對應關系,將得到的代碼變更信息、模型中的元素與代碼中的元素之間的對應關系翻譯為更新操作,產生新模型,實現(xiàn)模型同步。本發(fā)明可以集成在代碼版本管理系統(tǒng)中,能夠通過預定義規(guī)則,對軟件模型進行自動或半自動更新,保證軟件模型與代碼的一致性。
文檔編號G06F9/445GK103235729SQ20131013585
公開日2013年8月7日 申請日期2013年4月18日 優(yōu)先權日2013年4月18日
發(fā)明者王林章, 李袁奎, 李宣東, 陳志 申請人:南京大學