0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

六角架構學的三個原則和技術2

jf_78858299 ? 來源:超級架構師 ? 作者:南極真君 ? 2023-02-22 10:59 ? 次閱讀

細節(jié):內部和外部的代碼如何組織?

除了上面提到的原則,我們完全可以自由地按照我們的意愿在每個區(qū)域內組織代碼。

關于業(yè)務代碼,內部,一個好主意是選擇根據(jù)業(yè)務邏輯組織其模塊(或目錄)。

要避免的一個組織是按類型對類進行分組。例如“ports”目錄,或“repositories”目錄(如果使用此模式)或“services”目錄。在您的業(yè)務代碼中考慮100%的業(yè)務,包括組織您的模塊或目錄!理想的情況是能夠打開目錄或業(yè)務邏輯模塊,并立即了解您的程序解決的業(yè)務問題;而不是只看到“存儲庫”,“服務”或其他“經(jīng)理”目錄。

另請參閱此主題:

https://medium.com/@msandin/strategies-for-organizing-code-2c9d690b6f33

https://martinfowler.com/bliki/PresentationDomainDataLayering.html

細節(jié):運行時

您如何實例化所有這些以滿足運行時依賴性?如果您使用依賴注入框架,則可能不需要問自己這個問題。但我認為要理解六邊形體系結構,看看應用程序啟動時會發(fā)生什么是很有趣的。要做到這一點,至少在本文的時候不要使用依賴注入框架。

例如,如果我們手動實例化一切,我們將如何編寫應用程序的入口點:

class Program
{
 static void Main(string[] args)
 {
 // 1. Instantiate right-side adapter ("go outside the hexagon")
 IObtainPoems fileAdapter = new PoetryLibraryFileAdapter(@".\\Peoms.txt");
 // 2. Instantiate the hexagon
 IRequestVerses poetryReader = new PoetryReader(fileAdapter);
 // 3. Instantiate the left-side adapter ("I want ask/to go inside")
 var consoleAdapter = new ConsoleAdapter(poetryReader);
 System.Console.WriteLine("Here is some...");
 consoleAdapter.Ask();
 System.Console.WriteLine("Type enter to exit...");
 System.Console.ReadLine();
 }
}

實例化順序通常是從右到左:

  1. 首先我們實例化Infrastructure端,這里是fileAdapter,它將讀取文件。
  2. 我們實例化將由應用程序驅動的Domain類,poetryReader在其中通過注入將fileAdapter注入構造函數(shù)。
  3. 安裝Application端,consoleAdapter將驅動poetryReader并寫入控制臺。這里poetryReader通過注入構造函數(shù)注入consoleAdapter。

我們說內部不應該依賴于外部。那么為什么我們將來自Infrastructure的代碼fileAdapter注入poetryReader,這是來自Domain的代碼?

我們可以這樣做,因為通過查看模式和代碼,除了是PoetryLibraryFileAdapter(基礎結構方面)之外,fileAdapter也是繼承的IObtainPoems實例。

在實踐中,PoetryReader不依賴于PoetryLibraryFileAdapter,而是依賴于IObtainPoems,它在域中定義良好。您可以通過查看其構造函數(shù)的簽名來檢查它。

public PoetryReader(IObtainPoems poetryLibrary)
{
 this.poetryLibrary = poetryLibrary;
}

PoetryLibraryFileAdapter和PoetryReader是弱耦合的。

細節(jié):右側的依賴性反轉

fileAdapter依賴于業(yè)務的定義(依賴于繼承),但在運行時poetryReader可以在實踐中控制fileAdapter的實例是依賴倒置的經(jīng)典案例。

實際上,如果沒有IObtainPoems接口,業(yè)務代碼將依賴于其定義的基礎結構,我們希望避免:

圖片

該接口允許反轉此依賴關系的方向:

圖片

除了使業(yè)務獨立于外部系統(tǒng)之外,右側的此接口還允許滿足著名的 SOLID或Dependency Inversion Principle原則。這個原則說:

  1. 高級模塊不應該依賴于低級模塊。兩者都必須依賴于抽象。
  2. 抽象不應該依賴于細節(jié)。細節(jié)必須取決于抽象。

如果我們沒有接口,我們將擁有一個依賴于低級模塊(Infrastructure)的高級模塊(Domain)。

注意:對于左側和業(yè)務代碼之間的交互,依賴性自然是正確的方向。

圖片

交互實現(xiàn)的這種差異與應用程序域和域 - 基礎架構關系之間的差異有關。提醒:應用程序端驅動域,而基礎架構端由域驅動。

細節(jié):為什么左邊有接口?

由于Application和Domain之間的依賴關系已經(jīng)在正確的方向上,因此IRequestVerses接口的作用不是反轉依賴關系。

但是,它仍然有興趣:明確限制應用程序代碼和域代碼之間的耦合表面。

實際上,PoetryReader類可以有除IRequestVerses接口之外的其他方法。ConsoleAdapter不了解這一點很重要。

它與另一個SOLID原則 - 接口隔離原則一致。

客戶不應該被迫依賴他們不使用的方法。

圖片

但是,一旦你理解了意圖,如果左側的端口只有一個方法,并且它的實現(xiàn)只有一個方法,如我們的例子,接口真的是必要的嗎?在動態(tài)語言中,最終將通過duck typing?

我們可以回答一個問題:您的團隊對此有何看法?每個人都清楚隔離目標,甚至不需要界面來觸發(fā)對話嗎?這取決于你完全決定。

六角形結構測試

該軟件架構的一個重要優(yōu)點是它有助于測試自動化,這是其原始意圖的一部分。

如何從Application端替換一些代碼?

在一般情況下,左側代碼的作用可以由測試框架直接扮演。實際上,測試代碼可以直接驅動業(yè)務邏輯代碼。

圖片

注意:該圖說明了集成測試,因為沒有替換正確的部分。它也可以替換,見下文。

如何替換基礎設施方面的一些代碼?

右邊的代碼必須由業(yè)務驅動。通常,如果要編寫單元測試,可以使用模擬或任何其他形式的測試雙重替換它,具體取決于您要測試的內容。

達到了目標!

允許應用程序由用戶,程序,自動化測試或批處理腳本驅動,并與其可能的執(zhí)行系統(tǒng)和數(shù)據(jù)庫隔離開發(fā)和測試。

小心!這并不妨礙您測試應用程序和基礎結構代碼,任何值得測試的代碼。在這個主題上,我再次向您推薦實踐測試金字塔系列。

事實上,通過組合我們替換或不替換的內容,我們可以看到,通過這種架構,我們可以測試我們想要的東西:

  • 整個域單獨,
  • 在Infrastructure端獨立地集成Application和Domain
  • 在應用程序端獨立地集成域和基礎結構
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • Web
    Web
    +關注

    關注

    2

    文章

    1264

    瀏覽量

    69524
  • 代碼
    +關注

    關注

    30

    文章

    4798

    瀏覽量

    68725
收藏 人收藏

    評論

    相關推薦

    六角逆變器

    HEF4069UBP這個六角逆變器有什用?具體功能是什么?
    發(fā)表于 10-26 20:36

    MC14069UBDR2G六角逆變器的相關資料推薦

    MC14069UB六角形逆變器采用MOS P溝道構建和單通道中的N通道增強模式器件結構體。這些逆變器主要用于低功率需要耗散和/或高抗噪性。 六個中的每一逆變器是最小化傳播延遲的單一階段。特征?電源
    發(fā)表于 11-16 09:16

    一種改進的六角形砍邊細分方法

    研究了六角形網(wǎng)格上的曲面細分算法,改進了六角形網(wǎng)格砍邊細分算法。在邊形網(wǎng)格的砍邊細分過程中,利用對偶砍法對非六角形網(wǎng)格進行
    發(fā)表于 01-15 16:22 ?6次下載

    自行車輻條巧制內六角扳手

    自行車輻條巧制內六角扳手 家電維修時廠需要用到不同規(guī)格的內六角扳手。這類
    發(fā)表于 09-09 15:14 ?2580次閱讀
    自行車輻條巧制內<b class='flag-5'>六角</b>扳手

    MC14069UBDR2G六角逆變器

    MC14069UB六角形逆變器采用MOS P溝道構建和單通道中的N通道增強模式器件結構體。這些逆變器主要用于低功率需要耗散和/或高抗噪性。 六個中的每一逆變器是最小化傳播延遲的單一階段。特征?電源
    發(fā)表于 11-08 18:36 ?8次下載
    MC14069UBDR<b class='flag-5'>2</b>G<b class='flag-5'>六角</b>逆變器

    六角和內六角螺栓,該如何選擇?

    結構上,內六角螺栓和外六角螺栓很容易辨別。螺紋部分基本沒有差異,外六角是頭部的邊呈邊形,頭部沒有凹陷。為了增大頭部承壓面積,還可以做成外六角
    的頭像 發(fā)表于 01-08 11:29 ?2627次閱讀

    六角螺栓硬度等級及優(yōu)勢

    所謂的內六角螺栓就是指的圓柱頭為內六角形狀的,也可以稱為內六角螺釘,內六角圓柱頭螺釘和內六角螺絲。我們一般情況下常用的內
    的頭像 發(fā)表于 02-13 13:41 ?5578次閱讀

    六角反相器-74LV04

    六角反相器-74LV04
    發(fā)表于 02-15 19:34 ?0次下載
    <b class='flag-5'>六角</b>反相器-74LV04

    3.3 V 六角逆變器-74LVT04

    3.3 V 六角逆變器-74LVT04
    發(fā)表于 02-15 19:55 ?0次下載
    3.3 V <b class='flag-5'>六角</b>逆變器-74LVT04

    六角反相器-74ALVC04

    六角反相器-74ALVC04
    發(fā)表于 02-16 20:41 ?0次下載
    <b class='flag-5'>六角</b>反相器-74ALVC04

    六角反相器-74ABT04

    六角反相器-74ABT04
    發(fā)表于 02-17 19:23 ?0次下載
    <b class='flag-5'>六角</b>反相器-74ABT04

    六角架構三個原則技術1

    Hexagonal Architecture于2005年由Alistair Cockburn撰寫,是一具有許多優(yōu)勢的軟件架構,自2015年以來又重新引起了人們的興趣。 六角架構
    的頭像 發(fā)表于 02-22 10:46 ?671次閱讀
    <b class='flag-5'>六角</b><b class='flag-5'>架構</b><b class='flag-5'>學</b>的<b class='flag-5'>三個</b><b class='flag-5'>原則</b>和<b class='flag-5'>技術</b>1

    六角反相器-74LV04AT

    六角反相器-74LV04AT
    發(fā)表于 02-27 19:08 ?0次下載
    <b class='flag-5'>六角</b>反相器-74LV04AT

    六角逆變器數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《六角逆變器數(shù)據(jù)表.pdf》資料免費下載
    發(fā)表于 05-11 11:07 ?0次下載
    <b class='flag-5'>六角</b>逆變器數(shù)據(jù)表

    六角逆變器數(shù)據(jù)表

    電子發(fā)燒友網(wǎng)站提供《六角逆變器數(shù)據(jù)表.pdf》資料免費下載
    發(fā)表于 05-14 11:06 ?0次下載
    <b class='flag-5'>六角</b>逆變器數(shù)據(jù)表