面向對象分析方法

来源:http://www.cnblogs.com/houqian/archive/2016/07/21/5691631.html
-Advertisement-
Play Games

前言 讀《大象》的這一章節感覺很有指導意義,雖然工程中不能全部實踐,但作為心法來驅動設計是綽綽有餘了。 特質 一切都是對象 在面向對象者的眼裡,一切有名字的東西都是對象,都應該使用對象的觀點來看待它、分析他。哪怕這個東西的名字叫某某業務流程,它仍然應該看作是一個對象,而不是一個過程。這意味著,無論什 ...


前言

讀《大象》的這一章節感覺很有指導意義,雖然工程中不能全部實踐,但作為心法來驅動設計是綽綽有餘了。

特質


一切都是對象

在面向對象者的眼裡,一切有名字的東西都是對象,都應該使用對象的觀點來看待它、分析他。哪怕這個東西的名字叫某某業務流程,它仍然應該看作是一個對象,而不是一個過程。這意味著,無論什麼時候都應當採用接下來講述的一些觀點和方法來看待和分析事物。

對象都是獨立的

獨立性是面向對象的一大特點,承認對象的同時就接納了這一觀點。對象與對象之間是天然獨立的,知識在某個特定的場景下,他們的某一個特定的實例才相互的聯繫在一起。

我們獲取和分析對象的手段經常是通過分析某個場景,但是需要知道,對象是離散的,他不是因為該場景而存在的。場景中的對象知識對象『映射』到該場景中的一個側面,我們稱之為對象實例。換言之,通過一個場景,我們僅能得到對象的一個側面的信息。

對象都是獨立的

如果以每一個場景為坐標(維度),那麼對象實例就是對象在該坐標上的投影

每個維度就是更高層的抽象


 用例:蘋果(假設一筐中有許多蘋果,差異很大)

蘋果顏色,大小,口感是三個維度,那麼簡單的,紅色,中等大小,脆脆的就是框中蘋果們的一個實例。(假設可以根據這三個屬性(方面)來確定是一個蘋果)


要深入瞭解對象,我們經常需要分析很多歌該對象的實例所參與的場景,以獲得對象的多個側面,再通過歸納整理這些對象的多個實例抽象出對象的一般特性。

這就是對象的分析方法,同時也是使用UML來為對象建模時所採用的方法。

從圖2.4中,我們看到對象的產生、抽象並不是拍腦袋得來的。對象來源於場景分析,場景分析越多,我們對對象的瞭解越多,越精確。

有過項目經驗的讀者應該有深刻體會,在做過多個項目以後,會發現在許多項目當中相似的對象或者函數,會產生強烈的想把他們公共化得想法,這就是對象抽象的源動力。

從每個場景看到的僅是對象映射到該場景的一個方面,或者說是一個實例,他僅僅是對象分析的開始。

對象的獨立性帶來的正是對象的可抽象能力和可擴展能力。


請記住,當採用面向對象的方法時,在需求、分析、設計過程中,你所得到的任何一個有名字的東西,不論是用例、類、包、組件等都是獨立於那個場景的,不要將對象局限在那個場景中。


對象都具有原子性

無論在什麼時候,在同一抽象層次上,在分析過程中都應當將對象視為一個不可分割的原子,哪怕這個對象的規模很大。

例如在分析一個商業過程的時候,對象的規模(粒度)大到如銀行、工廠、商場的程度,不論它有多麼巨大,只要我們認為它是對象,它與其他對象交互時就是一個整體,不能分割。

原子性是抽象層次有意義的重要保證,一旦破壞了原子性,則表示在同一抽象層次上的對象不具備同樣的粒度,這使得分析工作陷入混亂。

在分析過程中,對象總有一個邊界,永遠也不應該打破邊界去窺探對象的內部。

形象一些說,對象看上去就像是一個個的雞蛋,蛋殼就是對象的邊界。在分析對象的過程中,我們對它的所有理解都是來自蛋殼。如果因為我們好奇心太重試圖瞭解殼以內的世界,衝動的打破了邊界,嗯,的確看到了,好奇心得到了滿足,不過很快就後悔了。因為雞蛋被破壞了,一灘黏黏糊糊的蛋清弄髒了手,很難收拾:P 糟糕的設計就像一堆破了殼的雞蛋,一片混亂。

我們應當將分析過程中得到的所有對於對象的認識附加在對象邊界上,在實現這個對象之前不理會其內部的細節。這就是傳說中的面向介面編程:P

對象都是可抽象的

對象有著許多個不同的方面。

一般來說,對象參與一個場景時會展現出某一個方面。總可以將對象的某一個方面抽象出來,讓其作為對象的一個代碼來參與場景交互。通常這種抽象會以介面來命名。

在分析過程中,得到的任何一個對象都有特定的方面可作為抽象。因為對象總是從場景分析中得到的,它在場景中肯定戰象了一個方面。

對象所具有的方面,或者說對象所參與的場景越多,對象越有抽象價值,反之則越沒有抽象價值。因此在分析過程中,應當關註於那些參與了很多場景的對象,他們往往是分析設計中的重點以及成敗關鍵。

對象都是有層次的

層次越高,其描述約粗略但適應能力越廣;層次越低則描述越精確但適應能力越下降。在分析過程中,應當根據問題領域的複雜程度設定多個抽象層次,在每個層次上使用合適的抽象程度的對象描述。這將有助於顯著的減少分析的難度和工作量。

不論是在需求、分析還是設計過程中,都應當具備抽象層次的觀點。從需求到設計的過程已經是幾個不同的抽象層次,筆者要說的是,在其中的一個階段,例如需求階段,仍然可以再多分幾個抽象層次來說明。具體分多少抽象層次應視問題領域的複雜程度而定。

總結

獨立性、原子性、抽象性和層次性是面向對象分析時應當遵循的一些原則和方法。在實際工作中,圖2.5所示的幾個方面是需要考慮的,如果該對象是一個關鍵對象,則應當儘量說明途中所示方面的內容。

對象分析方法


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 第一步:在tomcat啟動的時候 1、在tomcat啟動的時候,首先會載入struts2的核心過濾器StrutsPrepareAndExecuteFilter 我們打開源代碼,進入核心過濾器 在核心過濾器裡面有init()方法,用於在啟動tomcat的時候初始化struts2用的 首先我們去看一下如 ...
  • 簡介 一個很好的原則是調優時每次只個性一個配置。如果對配置的個性不能提高性能的話,改回預設值 優化必須要通過性能測試。不能意淫,需要前後對比,真實說明問題。 場景 1. 優化nginx。 2. 確保每次請求控制一定資源。 3. 減少訪問web容器 解決方案 nginx優化 全局優化 日誌 日誌是要讀 ...
  • 這兩天看了重溫了下設計模式和數據結構,又補了下基礎知識,然後就失眠了一整夜,不知為啥就想到級聯及偽刪數據這個問題。由於級聯刪除是幾乎人人都會遇到的問題,但方案卻有限卻不美好,所以歡迎大伙集思文益,以下內容歡迎大伙一起討論。 ...
  • 1.意圖 在布破壞封裝性的前提下,捕獲一個對象的內部狀態,併在該對象之外保存這個狀態。這樣以後就可以將對象恢復到原先保存的狀態。 2.別名 Token 3.動機 為了允許用戶取消不確定的操作或從錯誤中恢復過來,需要實現檢查點和取消機制,而要實現這些機制,必須將狀態信息保存在某處,這樣才能將對象恢復到 ...
  • 1.意圖 用一個中介對象來封裝一系列的對象交互。中介者使各個對象不需要顯示地相互引用,從而使其耦合鬆散,而且可以獨立地改變它們之間的交互。 2.動機 通過將集體行為封裝在一個單獨的中介者對象中,中介者負責控制和協調一組對象間的交互。中介者充當一個中介以使組中的對象不再相互顯示引用。這些對象只知道中介 ...
  • 享元(Flyweight)模式是一種經典的結構型設計模式,用於優化重覆、緩慢及數據共用效率較低的代碼。它旨在通過與相關對象共用儘可能多的數據來減少應用程式中記憶體的使用。 應用場景 (1)用於數據層,處理記憶體中保存的大量相似對象的共用數據。 (2)用於DOM層,Flyweight用作中央事件管理器,來 ...
  • 1.意圖 提供一種方法順序訪問一個聚合對象中的各個元素,而又不暴露該對象的內部表示。 2.別名 Cursor-游標。 3.動機 一個聚合對象,應該提供一種方法來讓別人可以訪問它的元素,而又不需暴露它的內部結構。 4.適用性 訪問一個聚合對象的內容而無需暴露它的內部表示。 支持聚合對象的多種遍歷。 為 ...
  • 一、什麼是CS和BS結構? 1.C/S又稱Client/Server或客戶/伺服器模式。伺服器通常採用高性能的PC、工作站或小型機,並採用大型資料庫系統,如Oracle、Sybase、Informix或SQLServer。客戶端需要安裝專用的客戶端軟體。 2.B/S是Brower/Server的縮寫 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...