搜尋
首頁後端開發C#.Net教程淺談GRASP軟體開發模式

你是優秀軟體開發人員嗎?你知道GRASP嗎? GRASP軟體開發模式,全名為通用職責分配軟體模式(General Responsibility Assignment Software Patterns),是與著名的軟體模式GoF(Gang of Four,即我們常說的那23種軟體開發模式)齊名的另一種軟體開發模式。但與GoF不同的是,它並不是提出一些具體的軟體組織結構,而是提出,在將現實世界的業務功能抽象成軟體開發中具體對象的過程中,我們應當遵循的一些基本原則。遵循這些基本原則,我們才可以開發出高品質的軟體出來。對於我們要開發的軟體項目,我們可以不使用工廠模式、可以不使用單例模式、我們也可以不使用觀察者模式,但是我們不可能不將現實世界的業務功能抽象化成軟體開發中具體對象。從這個角度說,我們要提升自己的軟體開發質量,深入理解GRASP比深入理解GoF更重要。但我看到現在介紹GoF的文章多,介紹GRASP文章少。正因為如此,我現在把GRASP介紹給大家。
GRASP包含了9個模式,也就是9個基本原則。這在軟體設計大師Craig Larman的經典著作《UML與模式應用》中進行了深入地講解。 GRASP叫通用職責分配軟體模式,要理解GRASP,我們必須先理解的一個問題是,我們在物件分析和設計過程中為什麼要進行職責分配。

#

一.職責分配與職責驅動設計

在一個軟體專案開始的時候,我們通常需要進行需求分析,了解客戶需要設計一個什麼樣的軟體,這個軟體中應該有什麼功能。需求分析了解到的是現實世界中客戶需求的業務功能,每個業務功能往往是一個業務流程,即客戶在日常工作中不斷在完成的業務流程。同時,在使用者的問題世界中,必然有一些東西或說事物,它們之間存在著相互的關聯。
拿一個軟體評審管理系統作為一個例子吧。評審管理系統的業務需求如下:
1.評審組織者制訂評審計劃,提交領導審批,然後透過電子郵件通知評審者。
2.評審者接獲通知,分別對評審對象進行評審,填寫評審表,並可對評審對象提出疑問。
3.評審組織者總結評審者的疑問,召開評審會議討論這些疑問。在會上,有些疑問變成問題,有些疑問不是問題,有些則依然無法確認。
4.會後,評審主辦單位整理疑問,形成評審報告,然後由評審者分別表決評審是否通過。最後評審組織者總結表決結果,形成評審結論。
5.評審組織者追蹤問題的解決。
透過以上需求的描述,我們不難發現整個問題世界中的相關事物:評審組織者、評審計畫、評審者、評審對象、評審表、疑問、評審報告、評審結論、問題。我們也不難分析出這些事物相互關係,例如評審計畫與評審者是一對多,而評審報告與評審結論是一對一。
在RUP中,業務需求將形成用例模型及其描述文件中的用例,事物及其關係將形成領域模型中的對象,當然如何製作用例模型和領域模型超出了本文討論的範圍,有興趣的朋友可以看看相關文章。
領域模型中的物件將成為軟體開發中形成具體物件的基礎(軟體開發中形成什麼物件是根據軟體開發的具體需求而定的,不一定要與領域模型的物件一致)。用例模型中的用例,將透過賦予這些物件行為而得以實現。現在的問題就出來了,用例模型中的功能,或者說一系列行為,要如何分配給這些物件呢。也就是說,為了完成同一個任務,我可以將行為A交給物件X,也可以交給物件Y。雖然交給物件X與交給物件Y,我對行為A的具體實作不一樣,但都可以完成行為A的任務。那麼,我到底該交給對象X還是對象Y呢?有沒有一個基本原則呢?有,那就是依照職責分配任務。雖然從理論上來說,我可以任意定義對象,可以讓對象沒有任何意義,或者去完成任意的工作,但是通常我們不會這樣去設計。通常我們會將物件與現實世界的物件連結起來,例如設計一個評審計畫物件、評審者物件。且我們在設計物件的時候應做到「低表示差異」。低表示差異就是我們設計的物件應與現實世界的物件盡量一致。比如說我們設計一個物件叫“評審者”,是因為我們在現實世界中有評審。同時,我們為評審者對象賦予的行為也應當盡量與現實世界一致,例如增加評審者、修改評審者、得到評審者資訊。那麼哪些是這個物件該賦予的行為呢,這要由職責來決定。
我們透過對現實世界的分析,或者說對於領域模型的分析,設計出了軟體系統中的對象,這時候我們應為每一個對象分配職責。什麼是對象的職責呢,當然是透過對現實世界的分析,定義的這個對象應當完成的任務。例如評審者對象的職責是存取與評審者相關的資料。當然對象的職責不一定是一個,例如評審計畫包含了評審對象和評審者的子項,所以它在工作不繁忙的情況下可以代理處理評審對象和評審者的資訊存取。但是一個對象的職責不應當過多(也就2、3個就行了)並且高度相關。例如評審表對像如果分配職責處理評審表的同時,又去處理評審計畫的數據,這就叫職責無關。
職責分配現在已經被普遍認為是優秀的軟體設計應遵循的原則,它有以下好處:
1.低表示差異使軟體結構清晰,易於理解,因為軟體開發並不是一個人的事情。在多人共同開發的軟體專案中,一目了然的軟體結構可以避免開發人員因誤解而造成的不必要錯誤。
2.易於維護和變更。如果評審計畫出了問題或需要修改,我們就去找評審計劃,如果是評審者的問題我們就去找評審者,而絕對不會與其它對像有關。
這種透過考慮物件、職責、協作的物件設計及構件方式,稱為「職責驅動設計(RDD,Responsibility Drive Design)」。職責驅動設計是透過先設計使用案例模型、使用案例模型描述、操作契約、系統順序圖、領域模型、詞彙表,再一步步製作分析模型、設計模型,寫出每個功能的交互圖、類別圖的很複雜的過程,我在這裡就不再詳述了。但請大家注意一個非常重要的細節,前面我們說,軟體系統中的物件是根據現實世界抽象得到,物件職責的分配是根據物件的定義,分配一些不多且高度相關的任務。然而我們即使遵照這些原則,也有相當大的設計彈性空間,不同人根據自己的理解,對於同一個功能依然有各自不同的設計。 GRASP中文譯為“通用職責分配軟體模式”,就是對物件分析和設計中職責分配問題提出數個基本原則。同時,這幾個基本原則也應掌握一個度,即並不是所有情況下都適用,也不是一個絕對的指標。例如低耦合,並不是絕對的不耦合,不耦合軟體就沒辦法設計了;高內聚也不能無限度高內聚,否則系統就繁複異常了。


二.GRASP模式挨個析

GRASP軟體設計模式包含9個模式:創建者、資訊專家、低耦合、控制器、高內聚、多態性、純虛構、間接性、防止變異。

#

以上是淺談GRASP軟體開發模式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
c#.net適合您嗎?評估其適用性c#.net適合您嗎?評估其適用性Apr 13, 2025 am 12:03 AM

c#.netissutableforenterprise-levelapplications withemofrosoftecosystemdueToItsStrongTyping,richlibraries,androbustperraries,androbustperformance.however,itmaynotbeidealfoross-platement forment forment forment forvepentment offependment dovelopment toveloperment toveloperment whenrawspeedsportor whenrawspeedseedpolitical politionalitable,

.NET中的C#代碼:探索編程過程.NET中的C#代碼:探索編程過程Apr 12, 2025 am 12:02 AM

C#在.NET中的編程過程包括以下步驟:1)編寫C#代碼,2)編譯為中間語言(IL),3)由.NET運行時(CLR)執行。 C#在.NET中的優勢在於其現代化語法、強大的類型系統和與.NET框架的緊密集成,適用於從桌面應用到Web服務的各種開發場景。

C#.NET:探索核心概念和編程基礎知識C#.NET:探索核心概念和編程基礎知識Apr 10, 2025 am 09:32 AM

C#是一種現代、面向對象的編程語言,由微軟開發並作為.NET框架的一部分。 1.C#支持面向對象編程(OOP),包括封裝、繼承和多態。 2.C#中的異步編程通過async和await關鍵字實現,提高應用的響應性。 3.使用LINQ可以簡潔地處理數據集合。 4.常見錯誤包括空引用異常和索引超出範圍異常,調試技巧包括使用調試器和異常處理。 5.性能優化包括使用StringBuilder和避免不必要的裝箱和拆箱。

測試C#.NET應用程序:單元,集成和端到端測試測試C#.NET應用程序:單元,集成和端到端測試Apr 09, 2025 am 12:04 AM

C#.NET應用的測試策略包括單元測試、集成測試和端到端測試。 1.單元測試確保代碼的最小單元獨立工作,使用MSTest、NUnit或xUnit框架。 2.集成測試驗證多個單元組合的功能,常用模擬數據和外部服務。 3.端到端測試模擬用戶完整操作流程,通常使用Selenium進行自動化測試。

高級C#.NET教程:ACE您的下一次高級開發人員面試高級C#.NET教程:ACE您的下一次高級開發人員面試Apr 08, 2025 am 12:06 AM

C#高級開發者面試需要掌握異步編程、LINQ、.NET框架內部工作原理等核心知識。 1.異步編程通過async和await簡化操作,提升應用響應性。 2.LINQ以SQL風格操作數據,需注意性能。 3..NET框架的CLR管理內存,垃圾回收需謹慎使用。

C#.NET面試問題和答案:提高您的專業知識C#.NET面試問題和答案:提高您的專業知識Apr 07, 2025 am 12:01 AM

C#.NET面試問題和答案包括基礎知識、核心概念和高級用法。 1)基礎知識:C#是微軟開發的面向對象語言,主要用於.NET框架。 2)核心概念:委託和事件允許動態綁定方法,LINQ提供強大查詢功能。 3)高級用法:異步編程提高響應性,表達式樹用於動態代碼構建。

使用C#.NET建築微服務:建築師實用指南使用C#.NET建築微服務:建築師實用指南Apr 06, 2025 am 12:08 AM

C#.NET是構建微服務的熱門選擇,因為其生態系統強大且支持豐富。 1)使用ASP.NETCore創建RESTfulAPI,處理訂單創建和查詢。 2)利用gRPC實現微服務間的高效通信,定義和實現訂單服務。 3)通過Docker容器化微服務,簡化部署和管理。

C#.NET安全性最佳實踐:防止常見漏洞C#.NET安全性最佳實踐:防止常見漏洞Apr 05, 2025 am 12:01 AM

C#和.NET的安全最佳實踐包括輸入驗證、輸出編碼、異常處理、以及身份驗證和授權。 1)使用正則表達式或內置方法驗證輸入,防止惡意數據進入系統。 2)輸出編碼防止XSS攻擊,使用HttpUtility.HtmlEncode方法。 3)異常處理避免信息洩露,記錄錯誤但不返回詳細信息給用戶。 4)使用ASP.NETIdentity和Claims-based授權保護應用免受未授權訪問。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),