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

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

嵌入式7種架構(gòu)模式分析

工程師進(jìn)階筆記 ? 來源:工程師進(jìn)階筆記 ? 2023-06-13 15:31 ? 次閱讀

嵌入式軟件因?yàn)?a target="_blank">硬件資源限制,可能存在驅(qū)動(dòng)與應(yīng)用耦合的情況,但對(duì)于大型項(xiàng)目,資源充裕的情況下,復(fù)雜的業(yè)務(wù)邏輯、后續(xù)擴(kuò)展維護(hù)的需要,必須采用分層和模塊化思維,這種思想就是架構(gòu)模式。一般分7種架構(gòu)模式:

分層架構(gòu)

②多層架構(gòu)

管道 - 過濾器架構(gòu)

④客戶端 - 服務(wù)器架構(gòu)

⑤模型 - 視圖 - 控制器架構(gòu)

事件驅(qū)動(dòng)架構(gòu)

微服務(wù)架構(gòu)

其中加粗部分屬于個(gè)人覺得適合在嵌入式系統(tǒng)應(yīng)用的架構(gòu)(模式),實(shí)際開發(fā)中一般是多種模式嵌套,確保軟件隔離解耦。

一、分層架構(gòu)模式

最常見的架構(gòu)模式就是分層架構(gòu),大部分分層架構(gòu)主要由四層組成:展現(xiàn)層、業(yè)務(wù)層、持久層和數(shù)據(jù)庫層,如下圖所示:

26eca6b4-0907-11ee-962d-dac502259ad0.jpg

1、上下文

復(fù)雜的系統(tǒng)都會(huì)經(jīng)歷獨(dú)立的發(fā)展和衍化系統(tǒng)各個(gè)部分的需要。出于這個(gè)原因,系統(tǒng)開發(fā)者需要對(duì)關(guān)注點(diǎn)進(jìn)行清晰且條理分明的分離,以便系統(tǒng)的各個(gè)模塊可以獨(dú)立地開發(fā)和維護(hù)。

2、問題

軟件需要以這樣一種方式分割:各個(gè)模塊可以獨(dú)自開發(fā)和衍化,各自部分之間的交互非常少,支持可移植性、可修改性和復(fù)用性。

3、方案

為了實(shí)現(xiàn)關(guān)注點(diǎn)分離,分層模式將軟件分割成各個(gè)單元(稱為“層”)。每一層都是一組模塊,提供了一組高內(nèi)聚的服務(wù)。其使用必須是單向的。層將一組軟件作為一個(gè)完整的分區(qū),每個(gè)分區(qū)暴露一個(gè)公開接口。

? 第一個(gè)概念是,每一層都有特定的角色和職責(zé)。例如,展現(xiàn)層負(fù)責(zé)處理所有的用戶界面。分層架構(gòu)的這種關(guān)注點(diǎn)分離,讓構(gòu)建高效的角色和職責(zé)非常簡單。

?第二個(gè)概念是,分層架構(gòu)模式是一個(gè)技術(shù)性的分區(qū)架構(gòu),而非一個(gè)領(lǐng)域性的分區(qū)架構(gòu)。它們是由組件組成的,而不是領(lǐng)域。

?最后一個(gè)概念是,分層架構(gòu)中的每一層都被標(biāo)記為封閉或者開放。封閉層意味著請求從一層移到另一層,它必須通過它正下面的這一層才能達(dá)到下面這一層的再下一層。請求不能跳過任何層。

26f1f7fe-0907-11ee-962d-dac502259ad0.jpg

4、弱點(diǎn)

分層會(huì)導(dǎo)致性能下降。這種模式不適合高性能應(yīng)用程序,因?yàn)榻?jīng)過架構(gòu)中的多層來實(shí)現(xiàn)一個(gè)業(yè)務(wù)請求的效率是不高的。還會(huì)增加系統(tǒng)的前期成本和復(fù)雜性。

5、用途

我們應(yīng)該將這種方式應(yīng)用于小型簡單的應(yīng)用程序。

點(diǎn)評(píng)

原文是針對(duì)互聯(lián)網(wǎng)軟件,對(duì)于嵌入式可以分為業(yè)務(wù)層、公共組件層、系統(tǒng)適配層、硬件驅(qū)動(dòng)層。軟件分層思想是個(gè)基礎(chǔ)概念,也許在嵌入式軟件中體現(xiàn)不明顯,是因?yàn)橛布Y源限制有所取舍。

二、多層模式

方案:

2705948a-0907-11ee-962d-dac502259ad0.jpg

許多系統(tǒng)的執(zhí)行結(jié)構(gòu)被組織成一系列邏輯組件分組。每個(gè)分組被稱為一個(gè)層。

1、上下文

在一個(gè)分布式部署中,通常需要將系統(tǒng)的基礎(chǔ)設(shè)施分到不同的子集中。

2、問題

我們?nèi)绾螌⑾到y(tǒng)分割到多個(gè)計(jì)算上獨(dú)立的執(zhí)行結(jié)構(gòu):由一些通信媒介連接的軟件和硬件組?

3、弱點(diǎn)

大量前期成本和復(fù)雜性。

4、用途

用在分布式系統(tǒng)中。

點(diǎn)評(píng)

個(gè)人能力限制,暫不明白在嵌入式軟件中的用法和使用范圍。

三、管道-過濾器架構(gòu)

軟件架構(gòu)中反復(fù)出現(xiàn)的一種模式是管道 - 過濾器(pipe-filter)模式。

27214e3c-0907-11ee-962d-dac502259ad0.jpg

1、上下文

許多系統(tǒng)需要轉(zhuǎn)換從輸入到輸出的離散數(shù)據(jù)流。許多類型轉(zhuǎn)換在實(shí)踐中重復(fù)出現(xiàn),因此將其創(chuàng)建成獨(dú)立的可復(fù)用的部分,這是比較理想的。

2、問題

這些系統(tǒng)需要被分割成可復(fù)用的松耦合的組件,組件之間擁有簡單通用的交互機(jī)制。這樣它們就可以靈活地相互結(jié)合。這些通用松耦合的組件就很容易復(fù)用。獨(dú)立的組件可以并行執(zhí)行。

3、方案

這種架構(gòu)中的管道構(gòu)成了過濾器之間的通信通道。第一個(gè)概念是,由于性能原因,每個(gè)管道都是非定向的和點(diǎn)對(duì)點(diǎn)的,接受來自一個(gè)源的輸入并經(jīng)常直接輸出到另外一個(gè)源。

在這種模式中,有如下四種過濾器。

? producer(source):一個(gè)過程的起點(diǎn)。

? transformer (map):對(duì)一些或所有數(shù)據(jù)進(jìn)行轉(zhuǎn)換。

? tester (reduce):測試一個(gè)或多個(gè)條件。

? consumer (sink):終點(diǎn)。

4、弱點(diǎn)

不太適合交互性的系統(tǒng),因?yàn)樗鼈兊霓D(zhuǎn)換特性。

過多的解析和反解析會(huì)導(dǎo)致性能損失,也會(huì)增加編寫過濾器本身的復(fù)雜性。

5、用途

管道 - 過濾器架構(gòu)用于各種應(yīng)用程序,特別是簡化單項(xiàng)處理的任務(wù)。

點(diǎn)評(píng)

看起來比較類似廣播與接收的模式,在無操作系統(tǒng)消息隊(duì)列機(jī)制,基于單片機(jī)裸機(jī)開發(fā)時(shí)可以使用,所有分時(shí)任務(wù)共享一個(gè)廣播隊(duì)列,接收時(shí)選擇自身感興趣的進(jìn)行處理,或者對(duì)廣播消息進(jìn)行刪除截?cái)嗪罄m(xù)操作。

四、客戶端-過濾器架構(gòu)

273116a0-0907-11ee-962d-dac502259ad0.jpg

1、上下文

有許多共享資源和服務(wù)是大量分布式的客戶端希望訪問的,希望控制訪問或服務(wù)質(zhì)量。

2、問題

通過管理一組共享資源和服務(wù),我們可以通過分解公共服務(wù)并在單個(gè)位置或少數(shù)位置進(jìn)行修改來提高可修改性和復(fù)用性。我們想要通過在將資源本身分布在多個(gè)物理服務(wù)器上的同時(shí)集中控制這些資源和服務(wù),來提高可伸縮性和可用性。

3、方案

在客戶端 - 服務(wù)器模式中,組件和連接器具有特定的行為。

稱為“客戶端”的組件將請求發(fā)送到稱為“服務(wù)器”的組件,然后等待回復(fù)。

服務(wù)器組件接收到客戶端的請求并向其發(fā)送回復(fù)。

4、弱點(diǎn)

服務(wù)器會(huì)成為性能瓶頸和單點(diǎn)故障位置。在系統(tǒng)建成后,關(guān)于功能位置(在客戶端還是在服務(wù)器)的決策通常是復(fù)雜的而且變動(dòng)成本很大。

5、用途

對(duì)于有許多組件(客戶端)發(fā)送請求到另外一些提供服務(wù)的組件(服務(wù)器)的系統(tǒng),我們可以使用客戶端 - 服務(wù)器模式來建模這個(gè)系統(tǒng)的一部分:在線應(yīng)用程序,例如電子郵件、共享文檔或銀行服務(wù)。

點(diǎn)評(píng)

這個(gè)好像只適合互聯(lián)網(wǎng)軟件。

五、模型-視圖-控制器架構(gòu)(MVC)

273c462e-0907-11ee-962d-dac502259ad0.jpg

1、上下文

用戶界面通常是一個(gè)交互性應(yīng)用程序的最頻繁被修改的部分。用戶通常希望從不同的視角查看數(shù)據(jù),例如柱狀圖或者餅圖。這些表示形式都應(yīng)該反映數(shù)據(jù)當(dāng)前的狀態(tài)。

2、問題

用戶界面功能如何獨(dú)立于應(yīng)用程序功能,同時(shí)還還對(duì)用戶輸入或底層應(yīng)用程序數(shù)據(jù)的更改做出響應(yīng)?

當(dāng)?shù)讓討?yīng)用程序數(shù)據(jù)更改時(shí),如何創(chuàng)建、維護(hù)和協(xié)調(diào)用戶界面的多個(gè)視圖?

3、方案

模型 - 視圖 - 控制器(model-view-controller,即 MVC)模式將應(yīng)用程序功能分為以下三種類型的組件:

?模型,包含應(yīng)用程序的數(shù)據(jù)。

?視圖,顯示部分底層數(shù)據(jù)并與用戶交互。

?控制器,在模型和視圖之間進(jìn)行中介并管理狀態(tài)更改的通知。

4、弱點(diǎn)

對(duì)于簡單的用戶界面,其復(fù)雜性并不值得這么做。

模型、視圖和控制器抽象可能不適用于某些用戶界面工具包。

5、用途

MVC 是網(wǎng)站或移動(dòng)應(yīng)用程序開發(fā)用戶界面常用的一種架構(gòu)模式。

點(diǎn)評(píng)

這模式一般用在支持顯示的場景,底層對(duì)數(shù)據(jù)的維護(hù)管理,與界面顯示分離,這樣當(dāng)業(yè)務(wù)需求、顯示部分變更對(duì)底層基礎(chǔ)影響較小,似乎是軟件分層模式的特例。

六、事件驅(qū)動(dòng)架構(gòu)

1、上下文

需要提供計(jì)算和信息資源來處理傳入的應(yīng)用程序生成的獨(dú)立異步事件,這種方式可以隨著需求的增加而擴(kuò)展。

2、問題

構(gòu)建分布式系統(tǒng),這個(gè)系統(tǒng)可以服務(wù)異步到達(dá)的事件相關(guān)信息,并且能從簡單小型擴(kuò)展到復(fù)雜大型。

3、方案

27460466-0907-11ee-962d-dac502259ad0.jpg

為事件處理部署獨(dú)立的事件進(jìn)程或處理器。到達(dá)的事件進(jìn)入隊(duì)列。調(diào)度程序根據(jù)調(diào)度策略從隊(duì)列中拉取事件并將它們分配到合適的事件處理器。

4、弱點(diǎn)

性能和錯(cuò)誤恢復(fù)可能是問題。

5、用途

使用這個(gè)方案的電商應(yīng)用程序?qū)⒐ぷ魅缦拢?/p>

Order Service 創(chuàng)建一個(gè) Order,這個(gè)訂單處于待定狀態(tài),然后發(fā)布一個(gè)OrderCreated事件。

? Customer Service 接收到這個(gè)事件并嘗試為這個(gè) Order 扣除信用。然后發(fā)布一個(gè) Credit Reserved 事件或者CreditLimitExceeded(超出信用限額)事件。

? Order Service 接收到 Customer Service 發(fā)送的事件并將訂單狀態(tài)更改為已核準(zhǔn)或已取消。

點(diǎn)評(píng)

這個(gè)在嵌入式軟件很容易理解,所謂事件就是硬件檢測到中斷信息。嵌入式軟件基本都有體現(xiàn)這個(gè)思想,一個(gè)while死循環(huán),等待事件觸發(fā),比如外部按鍵中斷、串口接收中斷、或者內(nèi)部定時(shí)器超時(shí)中斷等。這種框架有益于外設(shè)擴(kuò)展,理論上互不干擾。

七、微服務(wù)架構(gòu)

1、上下文

部署基于服務(wù)器的企業(yè)應(yīng)用程序,支持各種瀏覽器和原生移動(dòng)客戶端。應(yīng)用程序通過執(zhí)行業(yè)務(wù)邏輯、訪問數(shù)據(jù)庫、與其它系統(tǒng)交換信息并返回響應(yīng)來處理客戶端請求。這個(gè)應(yīng)用程序可能會(huì)暴露一個(gè)第三方 API。

2、問題

一體化應(yīng)用程序會(huì)變得過于龐大和復(fù)雜,無法得到有效支持和部署來實(shí)現(xiàn)最優(yōu)的分布式資源利用,例如在云環(huán)境中。

3、方案

2756060e-0907-11ee-962d-dac502259ad0.jpg

將應(yīng)用程序構(gòu)建成服務(wù)套件。每個(gè)服務(wù)都是獨(dú)立部署和可擴(kuò)展的,擁有自己的 API 邊界。不同的服務(wù)可以用不同的編程語言編寫,管理它們自己的數(shù)據(jù)庫,由不同的團(tuán)隊(duì)開發(fā)。

4、弱點(diǎn)

系統(tǒng)設(shè)計(jì)必須能容忍服務(wù)失敗,需要更多的系統(tǒng)監(jiān)控。服務(wù)編排和事件協(xié)作開銷比較大。

5、用途

許多使用場景都可以應(yīng)用微服務(wù)架構(gòu),特別是那些涉及大量數(shù)據(jù)管道的場景。例如,一個(gè)微服務(wù)系統(tǒng)對(duì)關(guān)于一個(gè)公司的零售店銷售的報(bào)表系統(tǒng)會(huì)比較理想。數(shù)據(jù)展現(xiàn)過程的每一步都會(huì)被一個(gè)微服務(wù)處理:數(shù)據(jù)收集、清理、規(guī)范化、濃縮、聚合、報(bào)告等。

點(diǎn)評(píng)

在嵌入式軟件開發(fā)中,比較適合某個(gè)相對(duì)獨(dú)立的功能,在適配其基礎(chǔ)接口后,將一個(gè)復(fù)雜功能模塊化,外部輸入參數(shù),模塊內(nèi)部執(zhí)行,結(jié)束后輸出結(jié)果或者觸發(fā)回調(diào),該功能對(duì)外接口簡單,外部無需過多關(guān)注內(nèi)部實(shí)現(xiàn),便于軟件解耦和維護(hù)。
責(zé)任編輯:彭菁

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 嵌入式
    +關(guān)注

    關(guān)注

    5059

    文章

    18973

    瀏覽量

    301997
  • 數(shù)據(jù)庫
    +關(guān)注

    關(guān)注

    7

    文章

    3752

    瀏覽量

    64229

原文標(biāo)題:你的嵌入式項(xiàng)目適合使用哪種軟件架構(gòu)?

文章出處:【微信號(hào):工程師進(jìn)階筆記,微信公眾號(hào):工程師進(jìn)階筆記】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    基于嵌入式實(shí)時(shí)系統(tǒng)設(shè)計(jì)模式的設(shè)計(jì)

    為滿足嵌入式實(shí)時(shí)系統(tǒng)快速適應(yīng)硬件型號(hào)升級(jí)、快速變更要求以及可伸縮、可修改、可復(fù)用等方面的需求,本文提出了一適用于嵌入式實(shí)時(shí)系統(tǒng)的設(shè)計(jì)模式--ERTSDP,解決了系統(tǒng)
    發(fā)表于 10-14 15:33 ?2810次閱讀
    基于<b class='flag-5'>嵌入式</b>實(shí)時(shí)系統(tǒng)設(shè)計(jì)<b class='flag-5'>模式</b>的設(shè)計(jì)

    嵌入式架構(gòu)有多重要?

    嵌入式架構(gòu)有多重要?要做到嵌入式應(yīng)用的代碼邏輯清晰,且避免重復(fù)的造輪子,沒有好的應(yīng)用架構(gòu)怎么行?如果沒有好的架構(gòu),移植將會(huì)是一件很痛苦的事情
    發(fā)表于 07-22 06:00

    嵌入式架構(gòu)有多重要

    嵌入式架構(gòu)有多重要?要做到嵌入式應(yīng)用的代碼邏輯清晰,且避免重復(fù)的造輪子,沒有好的應(yīng)用架構(gòu)怎么行?如果沒有好的架構(gòu),移植將會(huì)是一件很痛苦的事情
    發(fā)表于 10-27 08:15

    怎樣去設(shè)計(jì)一基于嵌入式架構(gòu)的指紋識(shí)別系統(tǒng)呢

    基于嵌入式架構(gòu)的指紋識(shí)別系統(tǒng)是由哪些部分組成的?怎樣去設(shè)計(jì)一基于嵌入式架構(gòu)的指紋識(shí)別系統(tǒng)呢?
    發(fā)表于 11-11 06:03

    基于軟件+服務(wù)平臺(tái)的軟件架構(gòu)模式

    本文在介紹軟件+服務(wù)平臺(tái)的概念的基礎(chǔ)上,設(shè)計(jì)了一基于軟件+服務(wù)平臺(tái)的軟件架構(gòu)模式,并對(duì)其核心組件進(jìn)行了說明,最后通過分析架構(gòu)的使用效果,從而說明了該
    發(fā)表于 06-10 10:33 ?27次下載

    嵌入式系統(tǒng)的發(fā)展特點(diǎn)及架構(gòu)分析

    嵌入式系統(tǒng)的發(fā)展特點(diǎn)及架構(gòu)分析    嵌入式系統(tǒng)已經(jīng)廣泛地應(yīng)用到當(dāng)今各個(gè)領(lǐng)域,與我們的生活息息相關(guān),小到掌上的數(shù)字產(chǎn)品,大到汽車、航天飛機(jī)。 提到
    發(fā)表于 11-28 08:55 ?656次閱讀

    嵌入式系統(tǒng)架構(gòu)發(fā)展趨勢及比較分析

    嵌入式系統(tǒng)架構(gòu)發(fā)展趨勢及比較分析 嵌入式系統(tǒng)已經(jīng)廣泛地應(yīng)用到當(dāng)今各個(gè)領(lǐng)域,與我們的生活息息相關(guān),小到掌上的數(shù)字產(chǎn)品,大到汽車、航天
    發(fā)表于 01-20 17:45 ?1110次閱讀

    簡便的基于ARM的嵌入式應(yīng)用開發(fā)模式

    簡便的基于ARM的嵌入式應(yīng)用開發(fā)模式
    發(fā)表于 09-22 16:40 ?4次下載
    一<b class='flag-5'>種</b>簡便的基于ARM的<b class='flag-5'>嵌入式</b>應(yīng)用開發(fā)<b class='flag-5'>模式</b>

    實(shí)例分析嵌入式系統(tǒng)電源設(shè)計(jì)

    的器件以及設(shè)計(jì)策略。 為電源電路規(guī)定具體的功能和架構(gòu)模塊并非微不足道,這些工作直接影響到電池供電系統(tǒng)的工作時(shí)間。電源系統(tǒng)架構(gòu)會(huì)因嵌入式產(chǎn)品和應(yīng)用領(lǐng)域的不同而各異。下圖是典型便攜嵌入式
    發(fā)表于 10-27 10:38 ?5次下載
    實(shí)例<b class='flag-5'>分析</b><b class='flag-5'>嵌入式</b>系統(tǒng)電源設(shè)計(jì)

    10常見的軟件體系架構(gòu)模式分析以及它們的用法、優(yōu)缺點(diǎn)

    架構(gòu)模式是一個(gè)通用的、可重用的解決方案,用于在給定上下文中的軟件體系結(jié)構(gòu)中經(jīng)常出現(xiàn)的問題。架構(gòu)模式與軟件設(shè)計(jì)模式類似,但具有更廣泛的范圍。
    的頭像 發(fā)表于 01-31 12:39 ?2.2w次閱讀
    10<b class='flag-5'>種</b>常見的軟件體系<b class='flag-5'>架構(gòu)模式</b><b class='flag-5'>分析</b>以及它們的用法、優(yōu)缺點(diǎn)

    詳解SOA五基本架構(gòu)模式

    本文詳細(xì)解說了SOA五基本架構(gòu)模式,面向服務(wù)的架構(gòu)(SOA)已成為連接復(fù)雜服務(wù)系統(tǒng)的主要解決方案。雖然SOA的理論很容易理解,但要部署一個(gè)設(shè)計(jì)良好、真正實(shí)用的SOA系統(tǒng)卻非常困難。本文試圖通過解析SOA的
    的頭像 發(fā)表于 02-07 14:41 ?2.1w次閱讀
    詳解SOA五<b class='flag-5'>種</b>基本<b class='flag-5'>架構(gòu)模式</b>

    一文帶你了解嵌入式領(lǐng)域三處理器通用的架構(gòu)

    嵌入式領(lǐng)域,存在著三處理器通用的架構(gòu),PowerPC、X86、ARM,本文將對(duì)這三架構(gòu)進(jìn)行對(duì)比分析
    發(fā)表于 03-05 17:39 ?5381次閱讀

    《C嵌入式編程設(shè)計(jì)模式》讀書筆記

    《C嵌入式編程設(shè)計(jì)模式》第一章 什么是嵌入式編程嵌入式系統(tǒng)的基本知識(shí)面向?qū)ο缶幊膛c結(jié)構(gòu)化編程使用C語言實(shí)現(xiàn)類、繼承、狀態(tài)機(jī)?第二章 嵌入式實(shí)
    發(fā)表于 11-03 16:06 ?13次下載
    《C<b class='flag-5'>嵌入式</b>編程設(shè)計(jì)<b class='flag-5'>模式</b>》讀書筆記

    架構(gòu)模式的基礎(chǔ)知識(shí)

    ????作為軟件工程師,為什么至少要學(xué)習(xí)基本的架構(gòu)模式? ????我相信有很多人回答了這個(gè)問題,但我會(huì)給你一些考慮的理由。 ????首先,如果您了解架構(gòu)模式的基礎(chǔ)知識(shí),那么您就更容易遵循架構(gòu)師的要求
    的頭像 發(fā)表于 06-13 16:13 ?694次閱讀
    <b class='flag-5'>架構(gòu)模式</b>的基礎(chǔ)知識(shí)

    嵌入式軟件最常見的架構(gòu)模式

    嵌入式軟件因?yàn)橛布Y源限制,可能存在驅(qū)動(dòng)與應(yīng)用耦合的情況,但對(duì)于大型項(xiàng)目,資源充裕的情況下,復(fù)雜的業(yè)務(wù)邏輯、后續(xù)擴(kuò)展維護(hù)的需要,必須采用分層和模塊化思維,這種思想就是架構(gòu)模式。一般分7
    的頭像 發(fā)表于 06-22 10:32 ?2446次閱讀
    <b class='flag-5'>嵌入式</b>軟件最常見的<b class='flag-5'>架構(gòu)模式</b>