目錄
一.職責分配與職責驅動設計
二.GRASP模式挨個析
首頁 後端開發 C#.Net教程 淺談GRASP軟體開發模式

淺談GRASP軟體開發模式

Mar 31, 2017 am 11:52 AM

你是優秀軟體開發人員嗎?你知道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

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1665
14
CakePHP 教程
1424
52
Laravel 教程
1322
25
PHP教程
1270
29
C# 教程
1250
24
c#.net的持續相關性:查看當前用法 c#.net的持續相關性:查看當前用法 Apr 16, 2025 am 12:07 AM

C#.NET依然重要,因為它提供了強大的工具和庫,支持多種應用開發。 1)C#結合.NET框架,使開發高效便捷。 2)C#的類型安全和垃圾回收機制增強了其優勢。 3).NET提供跨平台運行環境和豐富的API,提升了開發靈活性。

從網絡到桌面:C#.NET的多功能性 從網絡到桌面:C#.NET的多功能性 Apr 15, 2025 am 12:07 AM

C#.NETisversatileforbothwebanddesktopdevelopment.1)Forweb,useASP.NETfordynamicapplications.2)Fordesktop,employWindowsFormsorWPFforrichinterfaces.3)UseXamarinforcross-platformdevelopment,enablingcodesharingacrossWindows,macOS,Linux,andmobiledevices.

C#作為多功能.NET語言:應用程序和示例 C#作為多功能.NET語言:應用程序和示例 Apr 26, 2025 am 12:26 AM

C#在企業級應用、遊戲開發、移動應用和Web開發中均有廣泛應用。 1)在企業級應用中,C#常用於ASP.NETCore開發WebAPI。 2)在遊戲開發中,C#與Unity引擎結合,實現角色控制等功能。 3)C#支持多態性和異步編程,提高代碼靈活性和應用性能。

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,

C#.NET與未來:適應新技術 C#.NET與未來:適應新技術 Apr 14, 2025 am 12:06 AM

C#和.NET通過不斷的更新和優化,適應了新興技術的需求。 1)C#9.0和.NET5引入了記錄類型和性能優化。 2).NETCore增強了雲原生和容器化支持。 3)ASP.NETCore與現代Web技術集成。 4)ML.NET支持機器學習和人工智能。 5)異步編程和最佳實踐提升了性能。

.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應用程序部署到Azure/AWS:逐步指南 將C#.NET應用程序部署到Azure/AWS:逐步指南 Apr 23, 2025 am 12:06 AM

如何將C#.NET應用部署到Azure或AWS?答案是使用AzureAppService和AWSElasticBeanstalk。 1.在Azure上,使用AzureAppService和AzurePipelines自動化部署。 2.在AWS上,使用AmazonElasticBeanstalk和AWSLambda實現部署和無服務器計算。

C#和.NET運行時:它們如何一起工作 C#和.NET運行時:它們如何一起工作 Apr 19, 2025 am 12:04 AM

C#和.NET運行時緊密合作,賦予開發者高效、強大且跨平台的開發能力。 1)C#是一種類型安全且面向對象的編程語言,旨在與.NET框架無縫集成。 2).NET運行時管理C#代碼的執行,提供垃圾回收、類型安全等服務,確保高效和跨平台運行。

See all articles