當(dāng)前位置:首頁 > 嵌入式 > 嵌入式分享
[導(dǎo)讀]軟件體系結(jié)構(gòu)是其組件中體現(xiàn)的系統(tǒng)的基本組織,彼此之間的關(guān)系以及環(huán)境的關(guān)系以及指導(dǎo)其設(shè)計和進(jìn)化的原則。軟件體系結(jié)構(gòu)并不是要創(chuàng)建一次并將其設(shè)置為石頭。相反,軟件體系結(jié)構(gòu)應(yīng)在整個產(chǎn)品的一生中發(fā)展和變化。多年來,我聽到工程師和經(jīng)理討論了軟件體系結(jié)構(gòu)應(yīng)該從編碼工作中出現(xiàn),就好像是通過魔術(shù)一樣。相信一個新興的,干凈的建筑就像相信將一包意大利面倒入開水中會導(dǎo)致烤寬面條面條。

軟件體系結(jié)構(gòu)是其組件中體現(xiàn)的系統(tǒng)的基本組織,彼此之間的關(guān)系以及環(huán)境的關(guān)系以及指導(dǎo)其設(shè)計和進(jìn)化的原則。軟件體系結(jié)構(gòu)并不是要創(chuàng)建一次并將其設(shè)置為石頭。相反,軟件體系結(jié)構(gòu)應(yīng)在整個產(chǎn)品的一生中發(fā)展和變化。多年來,我聽到工程師和經(jīng)理討論了軟件體系結(jié)構(gòu)應(yīng)該從編碼工作中出現(xiàn),就好像是通過魔術(shù)一樣。相信一個新興的,干凈的建筑就像相信將一包意大利面倒入開水中會導(dǎo)致烤寬面條面條。

通過實(shí)施過程中考慮然后進(jìn)化的軟件體系結(jié)構(gòu)具有許多好處,例如:

· 充當(dāng)建造的路線圖

· 提供可用于培訓(xùn)工程師的軟件圖片,并向管理者和利益相關(guān)者解釋該軟件

· 最大程度地減少不必要的返工

· 發(fā)展成本降低

我經(jīng)??吹降囊粋€常見問題是,團(tuán)隊很難弄清楚如何定義他們的軟件體系結(jié)構(gòu)。團(tuán)隊可以使用五個步驟來開發(fā)和發(fā)展其軟件體系結(jié)構(gòu):

· 分開軟件體系結(jié)構(gòu)

· 識別和追蹤數(shù)據(jù)資產(chǎn)

· 分解系統(tǒng)

· 界面和組件設(shè)計

· 模擬,迭代和擴(kuò)展

因此,讓我們探索您可以采取的幾個步驟來設(shè)計嵌入式軟件體系結(jié)構(gòu)。

步驟#1 - 分開軟件體系結(jié)構(gòu)

許多嵌入式軟件團(tuán)隊將他們的軟件體系結(jié)構(gòu)視為包括應(yīng)用程序代碼和硬件交互的單個凝聚力體系結(jié)構(gòu)。以這種方式查看體系結(jié)構(gòu)并不奇怪,因為嵌入式軟件工程師通常會從硬件上查看其系統(tǒng)。嵌入式軟件是唯一的,因為它必須與硬件進(jìn)行交互,這與所有其他軟件工程領(lǐng)域都不同。雖然這是真的,但現(xiàn)代軟件架構(gòu)師將并且應(yīng)將與硬件依賴性和與硬件獨(dú)立的軟件分開。

我稱此分離為“兩個架構(gòu)的故事”。傳統(tǒng)上,開發(fā)人員將設(shè)計和實(shí)施其體系結(jié)構(gòu),以使硬件的獨(dú)立和依賴性層緊密結(jié)合。但不幸的是,緊密耦合的架構(gòu)存在很多問題。

緊密耦合體系結(jié)構(gòu)的問題

首先,它們不是很便攜。例如,如果微控制器突然變得不可用,會發(fā)生什么? (芯片短缺,有人嗎?)。如果代碼緊密耦合,則嘗試將應(yīng)用程序代碼移動以在新的微控制器上運(yùn)行,將成為一項艱巨的努力。應(yīng)用程序代碼與微控制器上的低級硬件調(diào)用緊密耦合!我知道許多最近遭受了苦難的公司。如果他們沒有更新架構(gòu),則必須返回所有代碼,并更改與硬件相互作用的每一行。更新其體系結(jié)構(gòu)的公司通過抽象和依賴注入打破了建筑耦合。

其次,幾乎不可能在開發(fā)環(huán)境中而不是在目標(biāo)硬件上測試應(yīng)用程序的單位測試。如果應(yīng)用程序代碼直接撥打了硬件,則可以成功運(yùn)行該測試的測試線束,或者需要在硬件上進(jìn)行測試。在硬件上進(jìn)行測試很慢,通常是手動的,而不是自動化過程。我看到的結(jié)果是,該軟件的測試無法很好地測試,整體系統(tǒng)質(zhì)量受到了損失。此外,交付軟件可能需要更長的時間。

最后,緊密耦合的體系結(jié)構(gòu)將存在可擴(kuò)展性問題。緊密耦合的系統(tǒng)通常共享數(shù)據(jù)。隨著軟件系統(tǒng)試圖增長和添加新功能,每個新功能都會添加新代碼變得更加困難。組件之間的相互作用,訪問共享數(shù)據(jù)的能力以及麻煩缺陷的機(jī)會急劇上升。結(jié)果,盡管開發(fā)人員為完成工作而努力工作,但功能開發(fā)仍可能停滯不前。

分隔建筑如何解決問題

將軟件體系結(jié)構(gòu)分為依賴硬件和獨(dú)立體系結(jié)構(gòu),通過緊密耦合的體系結(jié)構(gòu)解決了所有問題。例如,在硬件依賴性和獨(dú)立體系結(jié)構(gòu)之間創(chuàng)建一個抽象層,可以將應(yīng)用程序代碼從一個微控制器移動到下一個。抽象層打破了硬件依賴性;換句話說,應(yīng)用程序不知道或關(guān)心硬件。相反,應(yīng)用程序取決于接口。新的與硬件有關(guān)的組件只需滿足接口的要求即可。這意味著,如果我們更改硬件,只有硬件模塊會更改!不是整個代碼庫。

在兩個體系結(jié)構(gòu)之間添加抽象層也解決了單位測試的許多問題。在進(jìn)行抽象層時,更容易創(chuàng)建測試雙打和模擬將預(yù)期的數(shù)據(jù)和意外數(shù)據(jù)返回到應(yīng)用程序代碼。我們可以編寫所有應(yīng)用程序代碼,甚至沒有硬件!我知道這聽起來對許多嵌入式軟件開發(fā)人員來說是荒謬的。但是,在上周,我為正在開發(fā)的產(chǎn)品中添加了幾個新功能,我只打開了一次硬件。我所有的開發(fā)都是使用主機(jī)計算機(jī)上的單元測試完成的!

當(dāng)我們將體系結(jié)構(gòu)分開并專注于最小化耦合時,擴(kuò)展軟件變得更加容易。但是,僅僅因為我們打破了體系結(jié)構(gòu)并不意味著我們不能在每個體系結(jié)構(gòu)中創(chuàng)建耦合和凝聚力問題。我們?nèi)匀恍枰_保我們遵循兩個架構(gòu)中的堅實(shí)原則。好消息是,它使我們能夠獨(dú)立專注于每個體系結(jié)構(gòu),這意味著實(shí)時和硬件約束問題無法進(jìn)入核心應(yīng)用程序邏輯。

我要提到的最后一個好處是,通過將依賴硬件和獨(dú)立體系結(jié)構(gòu)分開,我們可以專注于在硬件可用之前開發(fā)和交付應(yīng)用程序。這里的好處是,可以盡早訪問該應(yīng)用程序并提供反饋。隨后迭代應(yīng)用程序并專注于確保其滿足實(shí)際需求的能力變得更加易于管理。如今,太多的團(tuán)隊專注于首先準(zhǔn)備硬件,而核心應(yīng)用程序是事后的想法。這是設(shè)計和構(gòu)建系統(tǒng)的方法。

結(jié)論

軟件體系結(jié)構(gòu)可以幫助團(tuán)隊控制他們的軟件。新興的軟件體系結(jié)構(gòu)通常會導(dǎo)致大球和意大利面條代碼。這并不意味著我們被迫使用瀑布方法。成功的軟件體系結(jié)構(gòu)通常是通過迭代和進(jìn)化來創(chuàng)建的。設(shè)計軟件體系結(jié)構(gòu)的第一步是認(rèn)識到嵌入式系統(tǒng)不僅沒有一個體系結(jié)構(gòu)。相反,有兩種體系結(jié)構(gòu):與硬件有關(guān)和獨(dú)立的體系結(jié)構(gòu)。有目的地分開這些架構(gòu),使開發(fā)人員能夠利用現(xiàn)代軟件技術(shù)和方法來改善市場,質(zhì)量和開發(fā)成本的時間。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉