分析与设计阶段-物件导向分析(ooa)

分析与设计阶段-物件导向分析(ooa)

ID:5405329

大小:751.00 KB

页数:68页

时间:2017-11-10

分析与设计阶段-物件导向分析(ooa)_第1页
分析与设计阶段-物件导向分析(ooa)_第2页
分析与设计阶段-物件导向分析(ooa)_第3页
分析与设计阶段-物件导向分析(ooa)_第4页
分析与设计阶段-物件导向分析(ooa)_第5页
资源描述:

《分析与设计阶段-物件导向分析(ooa)》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、第七章分析與設計階段–物件導向分析(OOA)軟體工程-物件導向程式設計與UML系統分析實作綱要分析與設計設計思維-SA/SDvs.Object-Oriented分析設計的”方法”物件導向分析階段(OOA)建立Use-Case模型(Use-CaseModeling)建立分析模型(ConceptualModeling)另一種OOA技術-CRCCards總結一般的開發流程文件的演進:由高階到低階(巨觀到微觀)分析階段的重點:規格文件的建置(通常基於特定技術)規格文件的撰寫比起需求文件,規格文件必須以更正式、更嚴謹、更有系統的方式來呈現:避免任何不完

2、整與矛盾的敘述可能為雙方制訂契約時的重要參考文件明確地描述出該產品所必須完成的事項例如:為了滿足某項需求,系統或軟體本身必須達成哪些功能或滿足某些條件(如:效率)。(Cont.)重點在勾勒出需完成的事項,但不需涉及到如何完成這些事項的細節(tellwhat,nothow)。通常基於特定之分析技術不論是結構化分析設計(StructuredAnalysis&Design–SA/SD)或物件導向分析設計(Object-OrientedAnalysis&Design–OOA/D),分析階段與設計階段所採用之技術通常要能夠互相搭配,如:一致的圖形表示方

3、式。分析階段相關技術正規的方法有限狀態機(FiniteStateMachine)Petrinets半正規的方法(介於正規非正規之間)實體關係模型(Entity-RelationshipModeling)結構化系統分析(StructuredSystemAnalysis)物件導向分析(OOA)–本書重點非正規的方法自然語言註:此分類方式參考自”ClassicalandObject-OrientedSoftwareEngineeringWithUmlandJava”(byStephenR.Schach)一書。(Cont.)不同的技術直接反映了文件的

4、呈現方式正規的方法精確度高有利正確性(Correctness)的理論證明較嚴謹可降低後期開發成本(錯誤率低!)不易學習、難以使用難以跟客戶端溝通(Cont.)非正規的方法(自然語言)易學易用容易跟客戶端溝通無法對規格文件有精確的描述,易造成文件的不完整、混淆以及矛盾等問題。半正規的方法比較折衷的技術,例如:實體關係模型(ERM)物件導向分析(OOA)非物件導向不可?答案是否定的!事實上,早期大多數成功的案例,皆採用了SA/SD技術(非物件導向)。但隨著軟體規模的日益膨脹,早期的方法(SA/SD)似乎不再能應付日趨複雜的軟體需求?!長久以來驗證

5、的結果,物件導向技術似乎更適用於現今的軟體需求!SA/SDvs.物件導向(OOA/D)根本差異:設計的思維~SA/SD:「資料」與「處理程序」分開思考OOA/D:「資料」與「處理程序」一起思考資料與處理程序資料:程式運作時所需之資料結構區域變數、全域變數、動態資料、檔案…等處理程序:程式運作(執行)之指令片段通常稱為函式(Function);同義詞:程序(Procedure/Sub-Routine)、功能(Action)。在物件導向的領域中則常稱為:操作(Operation)、行為(Behavior)、方法(Method)或成員函式(Memb

6、erFunction)。SA/SD之基本思維把「資料」與「處理程序」分開思考SA/SD相關技術資料導向技術:設計的重心落在系統所需之資料結構例如:常應用在關聯式資料庫之實體關係模型(ERM)圖形表示法+正規化(Formalization)資料模型(Cont.)程序導向技術:著重於處理的程序(以輸入/輸出為主體思考)例如:早期普遍被使用之資料流分析技術(DataFlowAnalysis)1.分析資料流(輸入輸出)形成高內聚力模組2.微調模組間的相依性降低模組間的耦合度在1&2過後(理論上):模組“處理程序”資料導向vs.程序導向何者為優

7、?為達某種程度的模組化效果,兩者似乎都難以避開進一步的調整動作~何謂好的模組?模組內-高內聚力(Cohesion)模組間-低耦合度(Coupling)模組化的好處易重複利用(MoreReusable)易維護減少錯誤的發生一個錯誤的發生不至於引發更多其他的錯誤(i.e.RegressionFaults)容易Debug易擴充模組化的根本問題減少相依性(Dependence)尤其是「資料與程序之間」的相依性SA/SD技術的罩門在SA/SD技術下(資料或程序導向),開發者將陷入疲於化解「資料與程序之間相依性」的窘境。但由上例中,看起來似乎沒有想像中複

8、雜?關鍵就在於:軟體需求的規模軟體規模越大相依關係的複雜度將越高OOA/D之基本思維把「資料」與「處理程序」一起思考減少模組化的負擔“資料抽象化”以及”封裝”等特

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。