項目度量
項目度量是針對軟件開(kāi)發(fā)項目的特定度量,目的在于度量項目規模、項目成本、項目進(jìn)度、顧客滿(mǎn)意度等,輔助項目管理進(jìn)行項目控制。
規模度量
軟件開(kāi)發(fā)項目規模度量(size measurement)是估算軟件項目工作量、編制成本預算、策劃合理項目進(jìn)度的基礎。規模度量是軟件項目失敗的重要原因之一。一個(gè)好的規模度量模型可以解決這一問(wèn)題。有效的軟件規模度量是成功項目的核心要素:基于有效的軟件規模度量可以策劃合理的項目計劃,合理的項目計劃有助于有效地管理項目。規模度量的要點(diǎn)在于:由開(kāi)發(fā)現場(chǎng)的項目成員進(jìn)行估算;靈活運用實(shí)際開(kāi)發(fā)作業(yè)數據;杜絕盲目迎合顧客需求的“交期逆推法”。
軟件規模度量有助于軟件開(kāi)發(fā)團隊準確把握開(kāi)發(fā)時(shí)間、費用分布以及缺陷密度等等。軟件規模的估算方法有很多種,如:功能點(diǎn)分析(FPA:function points analysis)、代碼行(LOC:lines of code)、德?tīng)柗品?Delphi technique)、COCOMO模型、特征點(diǎn)(feature point)、對象點(diǎn)(object point)、3-D功能點(diǎn)(3-D function points)、Bang度量(DeMarco's bang metric)、模糊邏輯(fuzzy logic)、標準構件法(standard component)等,這些方法不斷細化為更多具體的方法。
1. 功能點(diǎn)分析法
(1)功能點(diǎn)分析法概述
功能點(diǎn)分析法(FPA:function point analysis)是在需求分析階段基于系統功能的一種規模估算方法,是基于應用軟件的外部、內部特性以及軟件性能的一種間接的規模測量。FPA法由IBM的工程師艾倫·艾爾布策(Allan Albrech)于20世紀70年代提出,隨后被國際功能點(diǎn)用戶(hù)協(xié)會(huì )(IFPUG:The International Function Point Users' Group)提出的IFPUG方法繼承,從系統的復雜性和系統的特性這兩個(gè)角度來(lái)度量系統的規模,其特征是:“在外部式樣確定的情況下可以度量系統的規!,“可以對從用戶(hù)角度把握的系統規模進(jìn)行度量”。功能點(diǎn)可以用于“需求文檔”、“設計文檔”、“源代碼”、“測試用例”度量,根據具體方法和編程語(yǔ)言的不同,功能點(diǎn)可以轉換為代碼行。經(jīng)由ISO組織已經(jīng)有多種功能點(diǎn)估算方法成為國際標準,如:①加拿大人艾倫·艾布恩(Alain Abran)等人提出的全面功能點(diǎn)法(full function points);②英國軟件度量協(xié)會(huì )(UKSMA:United Kingdom Software Metrics Association)提出的IFPUG 功能點(diǎn)法(IFPUG function points);③英國軟件度量協(xié)會(huì )提出的Mark II FPA功能點(diǎn)法(Mark II function points);④荷蘭功能點(diǎn)用戶(hù)協(xié)會(huì )(NEFPUG:Netherlands Function Point Users Group)提出的NESMA 功能點(diǎn)法,以及軟件度量共同協(xié)會(huì )(COSMIC:the COmmon Software Metrics Consortium)提出的COSMIC-FFP方法,這些方法都屬于艾爾布策功能點(diǎn)方法的發(fā)展和細化。
(2)功能點(diǎn)分析法的基本計數
功能點(diǎn)分析的基本計數就是依據標準計算出的系統(或模塊)中所含每一種元素的數目:
、偻獠枯斎霐(EI:external input):計算每個(gè)用戶(hù)輸入,它們向軟件提供面向應用的數據。輸入應該與查詢(xún)區分開(kāi)來(lái),分別計算。
、谕獠枯敵鰯(EO:external output):計算每個(gè)用戶(hù)輸出,它們向軟件提供面向應用的信息。這里,輸出是指報表、屏幕、出錯信息,等等。一個(gè)報表中的單個(gè)數據項不單獨計算。
、弁獠坎樵(xún)數(EQ:external query):一個(gè)查詢(xún)被定義為一次聯(lián)機輸入,它導致軟件以聯(lián)機輸出的方式產(chǎn)生實(shí)時(shí)的響應。每一個(gè)不同的查詢(xún)都要計算。
、軆炔窟壿嬑募(ILF:internal logical file):計算每個(gè)邏輯的主文件,如數據的一個(gè)邏輯組合,它可能是某個(gè)大型數據庫的一部分或是一個(gè)獨立的文件。
文章來(lái)源于領(lǐng)測軟件測試網(wǎng) http://kjueaiud.com/