首頁 後端開發 C#.Net教程 分層開發思想與小籠包

分層開發思想與小籠包

Apr 30, 2017 am 10:26 AM

  早上吃早點的時候,突發靈感,結合吃的小籠包和日常的開發經驗來說一下分層的應用。 

首先,談談什麼是三層架構,所謂的三層開發就是將整個業務應用劃分為表示層-業務邏輯層―資料存取層-資料庫等,有的還要細一些,明確地將客戶端的表示層、業務邏輯存取、和資料存取及資料庫存取劃分出來,十分有利於系統的開發,維護、部署和擴展。 

  軟體要分層,其實總結一句話,是為了實現「高內聚、低耦合」。採用「分而治之」的思想,把問題分割開來各個解決,易於控制,易於延展,易於分配資源。  

  這種三層結構有什麼優點呢?  

  1. 透過將整個系統分為不同的邏輯區塊,大大降低了應用系統開發和維護的成本。 

三層結構將表示部分和業務邏輯部分按照客戶層和應用伺服器相分離,客戶端和應用伺服器、應用伺服器和資料庫伺服器之間的通訊以及異質平台之間的資料交換等都可以透過中間件或者相關程序來實現。當資料庫或應用伺服器的業務邏輯改變時,客戶端並不需要改變,反之亦然,從而大大提高了系統模組的複用性,縮短了開發週期,降低了維護費用。 

  趣味理解: 

  假設飯店可以這樣做小籠包:  

  一層蒸餃,  

  一層肉包,      

  一層素包。  

  首先這種方式我們可以讓做包子的分成不同的小組,來負責做不同的包子。當做好了每一種包子,他們可以很方便的知道,該放到哪個籠裡,不至於挨個去查看該放在哪裡,我們也很容易地將籠子放到火上面去,而不會影響其他籠的加熱。當我們要吃肉包或蒸餃時,我們也很容易找到我們所需要的,非常節省時間和體力。把肉包或蒸餃拿走或增加,並不影響素包的加熱。  

  如果我們把這些都放在一個大籠子裡,你覺得會怎麼樣?會不會很亂,維護起來很浪費時間,不但找起來麻煩,而其每次揭開鍋子都會對其他的有影響。   

  2. 將資料存取和邏輯操作都集中到元件中,增強了系統的複用性。  

  如:將資料存取集中到資料存取層的元件中,從而減少了應用程式中的重複程式碼,每個需要存取資料庫、表格的窗體都使用相同的元件。  

  如:一些共性的邏輯操作都集中封裝在邏輯層的元件中,每一個使用該方法的操作,可以共用來存取該元件。  

  趣味理解:  

簡單的理解,籠抽屜本身就是一個重用的例子,如果我們使用一次性的籠(像一次性筷子一樣理解),會浪費多少人工來做啊(重複編寫麻煩),並且會有很大的資源浪費(程式碼冗餘),最後還要進行垃圾處理(後期維護)。並且,如果籠子和爐火的鍋子是依照一種規範和標準(接口)來做,這樣的籠子不但可以在這裡用,也可以拿到別的地方用。 (雖然這樣理解不太確切,簡單的這樣理解好了) 

  3. 系統的擴展性大大增強。 

  模組化使得系統很容易在縱向和水平兩個方向拓展:一方面可以將系統升級為更大、更有力的平台,同時也可以適當增加規模來增強系統的網路應用。由於擺脫了系統同構性的限制,使得分佈資料處理成為可能。在擴充或修改功能時,基本上不會破壞原有結構的穩定性。  

  趣味理解: 

  隨著顧客的需要,我們現在需要增加新品種,如蒸饅頭,蒸地瓜,那麼直接可以增加一層籠就是了,對其他籠不會有什麼影響。   

三層結構在營造企業競爭優勢中的作用主要體現在模組化設計使得用戶在現有結構的基礎上實現了系統擴展,從而提高企業資訊化的速度和業務水平;同時三層結構中中間件的出現使得用戶可以直接從市場上選擇合適的產品來建立系統,大大降低了開發週期和開發成本。   

  但分層結構也有缺點也不是越多越好,那樣管理很多層會比較麻煩,運作效率可能比較低。所以,一個具備良好層次結構的系統,其層的數目要恰到好處才行。

相關文件:三層架構與養豬

以上是分層開發思想與小籠包的詳細內容。更多資訊請關注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

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

熱工具

記事本++7.3.1

記事本++7.3.1

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

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

C語言各種符號的使用方法 C語言各種符號的使用方法 Apr 03, 2025 pm 04:48 PM

C 語言中符號的使用方法涵蓋算術、賦值、條件、邏輯、位運算符等。算術運算符用於基本數學運算,賦值運算符用於賦值和加減乘除賦值,條件運算符用於根據條件執行不同操作,邏輯運算符用於邏輯操作,位運算符用於位級操作,特殊常量用於表示空指針、文件結束標記和非數字值。

char在C語言字符串中的作用是什麼 char在C語言字符串中的作用是什麼 Apr 03, 2025 pm 03:15 PM

在 C 語言中,char 類型在字符串中用於:1. 存儲單個字符;2. 使用數組表示字符串並以 null 終止符結束;3. 通過字符串操作函數進行操作;4. 從鍵盤讀取或輸出字符串。

char在C語言中如何處理特殊字符 char在C語言中如何處理特殊字符 Apr 03, 2025 pm 03:18 PM

C語言中通過轉義序列處理特殊字符,如:\n表示換行符。 \t表示製表符。使用轉義序列或字符常量表示特殊字符,如char c = '\n'。注意,反斜杠需要轉義兩次。不同平台和編譯器可能有不同的轉義序列,請查閱文檔。

c#多線程和異步的區別 c#多線程和異步的區別 Apr 03, 2025 pm 02:57 PM

多線程和異步的區別在於,多線程同時執行多個線程,而異步在不阻塞當前線程的情況下執行操作。多線程用於計算密集型任務,而異步用於用戶交互操作。多線程的優勢是提高計算性能,異步的優勢是不阻塞 UI 線程。選擇多線程還是異步取決於任務性質:計算密集型任務使用多線程,與外部資源交互且需要保持 UI 響應的任務使用異步。

char與wchar_t在C語言中的區別 char與wchar_t在C語言中的區別 Apr 03, 2025 pm 03:09 PM

在 C 語言中,char 和 wchar_t 的主要區別在於字符編碼:char 使用 ASCII 或擴展 ASCII,wchar_t 使用 Unicode;char 佔用 1-2 個字節,wchar_t 佔用 2-4 個字節;char 適用於英語文本,wchar_t 適用於多語言文本;char 廣泛支持,wchar_t 依賴於編譯器和操作系統是否支持 Unicode;char 的字符範圍受限,wchar_t 的字符範圍更大,並使用專門的函數進行算術運算。

char在C語言中如何進行類型轉換 char在C語言中如何進行類型轉換 Apr 03, 2025 pm 03:21 PM

在 C 語言中,char 類型轉換可以通過:強制類型轉換:使用強制類型轉換符將一種類型的數據直接轉換為另一種類型。自動類型轉換:當一種類型的數據可以容納另一種類型的值時,編譯器自動進行轉換。

char和unsigned char的區別是什麼 char和unsigned char的區別是什麼 Apr 03, 2025 pm 03:36 PM

char 和 unsigned char 是存儲字符數據的兩種數據類型,主要區別在於處理負數和正數的方式:值範圍:char 有符號 (-128 到 127),unsigned char 無符號 (0 到 255)。負數處理:char 可以存儲負數,unsigned char 不能。位模式:char 最高位表示符號,unsigned char 無符號位。算術運算:char 和 unsigned char 作為有符號和無符號類型,其算術運算方式不同。兼容性:char 和 unsigned char

C語言中char的常見錯誤及避免方法 C語言中char的常見錯誤及避免方法 Apr 03, 2025 pm 03:06 PM

C語言中char的使用錯誤和避免方法:未初始化char變量:使用常量或字符串文字初始化。超出字符範圍:比較變量值是否在有效範圍內(-128 到 127)。字符比較不區分大小寫:使用toupper()或tolower()轉換字符大小寫。使用char*引用字符數組時未加'\0':使用strlen()或手動添加'\0'標記數組結尾。使用char數組時忽略數組大小:明確指定數組大小或使用sizeof()確定長度。使用char指針時未檢查空指針:使用前檢查指針是否為NULL。使用char指針指向非字符數據

See all articles