當(dāng)前位置:首頁 > 公眾號精選 > 21ic電子網(wǎng)
[導(dǎo)讀]寫在前面剛開始學(xué)51、STM32單片機(jī),自然還是要從裸機(jī)開始跑,但是隨著寫的裸機(jī)軟件越來越多,裸機(jī)所暴露的問題也越來越多。那么,裸奔和操作系統(tǒng)到底有什么區(qū)別呢?裸奔的局限性1、并發(fā)性:程序并發(fā)工作效率低在寫裸機(jī)軟件時,不可避免的在主程序中會有一個超級大的while(1)循環(huán),這里...

裸奔,還是上操作系統(tǒng)?兩者有啥區(qū)別?

寫在前面

剛開始學(xué) 51 、STM32單片機(jī),自然還是要從裸機(jī)開始跑,但是隨著寫的裸機(jī)軟件越來越多,裸機(jī)所暴露的問題也越來越多。那么,裸奔和操作系統(tǒng)到底有什么區(qū)別呢?

裸奔的局限性

1、并發(fā)性:程序并發(fā)工作效率低在寫裸機(jī)軟件時,不可避免的在主程序中會有一個超級大的 while(1) 循環(huán),這里面幾乎包含整個項目的所有業(yè)務(wù)邏輯。因為每個業(yè)務(wù)邏輯里面都會有 delay 這樣的循環(huán)等待函數(shù),這樣導(dǎo)致了所有的業(yè)務(wù)邏輯幾乎都是串行起來工作的。這個時候 CPU 就會有很多時間都浪費(fèi)在了延時函數(shù)里,一直在空轉(zhuǎn),導(dǎo)致軟件的并發(fā)效率非常差。
2、模塊化:高內(nèi)聚、低耦合的原則從軟件工程的角度,我們在做軟件開發(fā)時,都會強(qiáng)調(diào)高內(nèi)聚、低耦合的原則。而裸機(jī)的模塊化開發(fā)難度非常大,模塊間的耦合較重,這也導(dǎo)致了無法在大型項目使用裸機(jī)來開發(fā)。還是剛才 main 函數(shù)中大 while(1) 的例子,可以想象到那么多功能都緊緊的擠在一個函數(shù)里,不可拆分,模塊化開發(fā)的困難重重。
舉一個非常貼切的例子,在一些使用看門狗的項目中,如果使用 delay 延時函數(shù),那得注意點(diǎn),萬一延時過長,主函數(shù)來不及喂狗,看門狗就被觸發(fā)了。最后會產(chǎn)生這樣一種感覺,一個簡簡單單的 delay 還得考慮喂狗功能,裸機(jī)開發(fā)時操的心太多了,自然無法應(yīng)用在大型項目中。
3、生態(tài):很多高級軟件組件,必須依賴于操作系統(tǒng)來實現(xiàn)比如說,我前些年開源過一個基于 FreeModbus 的 Modbus 主機(jī)協(xié)議棧,因為要考慮各個平臺適配問題,原本計劃支持各種各樣的操作系統(tǒng),甚至是裸機(jī)平臺。在各個操作系統(tǒng)上的適配都非常容易,但再去嘗試著適配裸機(jī)時,發(fā)現(xiàn)難度重重,有一些函數(shù)在裸機(jī)上實現(xiàn)起來非常復(fù)雜,而且針對于不同的裸機(jī)環(huán)境,幾乎沒有通用性可言,太耗費(fèi)精力了。所以我最終就放棄了裸機(jī)適配,一直到現(xiàn)在,在裸機(jī)上還是沒法用這個 Modbus 主機(jī)協(xié)議棧。
還有一些軟件無法運(yùn)行在裸機(jī)上,比如:樂鑫、Realtek、 ti 和 聯(lián)發(fā)科 提供的 WIFi SOC SDK ,一些藍(lán)牙 SOC 的 SDK 也都是只支持操作系統(tǒng),所以,如果你不了解、不會使用操作系統(tǒng),這些芯片也就玩不轉(zhuǎn)了。
4、實時性:功能復(fù)雜的情況下,實時性無法保證軟件的實時性在一些領(lǐng)域會有一定的要求,軟件的每個步驟必須在指定的時間被觸發(fā)。工控領(lǐng)域就是最常見到的場景,如果實時性無法保證,機(jī)械設(shè)備可能就無法按照指定時序要求去動作,以至于發(fā)生機(jī)械事故,甚至?xí){到人的生命。回過來接著看裸機(jī)軟件,如果軟件變得龐大以后,可以想象到,主程序中那么大的一個 while(1) 循環(huán),代碼耦合嚴(yán)重,到處都是 delay 延時,要保證實時性幾乎是不可能的。
5、可重用性:軟件可重用性差,總是重復(fù)造輪子可重用性與模塊化程度有直接的關(guān)系。相信大家每個人在工作中都不想做很多重復(fù)性的工作,同樣在寫代碼時,也想著盡可能少寫一些功能相似的代碼。但在這個嵌入式碎片化極其嚴(yán)重的時代,各式各樣的芯片,想要讓同樣的代碼,在裸機(jī)環(huán)境下同時適配不同的硬件,難度非常大。這樣也就導(dǎo)致了裸機(jī)的代碼會過多的依賴于底層硬件,重復(fù)造輪子的過程也就不可避免。操作系統(tǒng)帶來的優(yōu)勢
第一次接觸操作系統(tǒng),是在 2010 年左右,那時 STM32 已經(jīng)開始流行起來,這么強(qiáng)大的單片機(jī),有很多人都在上面跑操作系統(tǒng),我也跟著移植了 ucos ,在上面還跑了 ucgui ,這個時候?qū)憫?yīng)用完全是一種全新的體驗,爽了很多,玩了一年了 ucos ,后來接觸到咱們國產(chǎn)的 RT-Thread ,在它上面有很多現(xiàn)成的、拿來即用組件,試用以后發(fā)現(xiàn)更爽,就一直用到了今天,大概有 8 年了。

操作系統(tǒng)的優(yōu)越性

1、 模塊化使用了操作系統(tǒng)以后,整個軟件的工作被拆分成了由多個任務(wù)來構(gòu)成(也會被稱為線程),每個線程有自己獨(dú)立的運(yùn)行空間,即線程堆棧,這個時候每個線程你玩你的,我做我的,咱們大家互補(bǔ)干涉,模塊化程度得到很好的提高。
2、 并發(fā)性從并發(fā)的角度來看,各個線程在使用 delay/事件等待 這類函數(shù)時,會自動的讓出 CPU 給其他有需要的線程,不僅書寫 delay 延時函數(shù)操的心少了,整個 CPU 的利用率也得到了提高,最終提升并發(fā)性。
3、 實時性再來看實時性,像 ucos/RT-Thread 這些 RTOS 本身就被設(shè)計為實時的操作系統(tǒng),各個線程都有不同的優(yōu)先級別,重要的線程可以設(shè)為高優(yōu)先級,不重要的線程可以降低優(yōu)先級,做好全局的統(tǒng)籌規(guī)劃后,這樣整個軟件的實時性也能得到保證。
4、開發(fā)效率由于操作系統(tǒng)提供了統(tǒng)一的抽象接口層,方便了可重用組件的積累,提高開發(fā)效率。操作系統(tǒng)其實是一群軟件大牛們智慧的結(jié)晶,他們站在應(yīng)用軟件、底層驅(qū)動的開發(fā)角度,對很多常見的軟件功能進(jìn)行了封裝、抽象,比如:信號量、事件通知、郵箱、環(huán)形緩沖區(qū)、單向鏈表/雙向鏈表等等,這些功能拿來即用,對于開發(fā)者方便極了
還有一些操作系統(tǒng),比如:Linux 和我們國產(chǎn)的 RT-Thread ,他們這些系統(tǒng)對碎片化的硬件,統(tǒng)一封裝了一套標(biāo)準(zhǔn)的硬件操作接口,一般稱為設(shè)備驅(qū)動框架。這樣我們的應(yīng)用軟件工程師,就可以專攻應(yīng)用的工作,再也不用怕更換硬件,又需要重復(fù)造輪子了。
5、軟件生態(tài)生態(tài)的豐富帶來了量變到質(zhì)變的過程(自己玩->大家一起玩)
使用操作系統(tǒng)所帶來的軟件可模塊化、重用性的提升,也使得我們自己在做軟件開發(fā)時,可以封裝一套基于操作系統(tǒng)、適合嵌入式的可重用組件,這些組件不僅可以用在自己的項目中,還能開源出來分享給更多有需要的嵌入式開發(fā)者,把軟件的價值最大化。
個人感覺這是一件蠻有意義事情,我自己本身也是一名開源極客,也有在 GitHub 上開源一些嵌入式軟件。說實話在做開源軟件前,能夠深入交流嵌入式軟件的地方非常少,畢竟大家的代碼不是芯片不一樣,就是硬件不一樣,你的代碼給了他,也不一定能運(yùn)行起來。但是自從用了操作系統(tǒng)后,軟件的可重用性提高了,能夠讓更多的人很迅速的用起來我的開源軟件,這個時候能夠有更多的人可以一起交流,還接觸到了很多的大牛們,甚至是國外的朋友。俗話說:水漲船高,我的能力也從此得到了快速的提升。所以總結(jié)下來,有一個能一起交流嵌入式軟件圈子還是蠻重要的,自己閉門造車,可能都是在重復(fù)造輪子。

常見RTOS優(yōu)勢對比

ucos/freertos/RT-Thread,選擇這三款 OS 的原因是,它們的年限都比較長了,在市面上都蠻有知名度,用過的人比較多,更有說服力。
1、 基本功能、性能各家 RTOS 差異很小,可比性并不是很大
2、 易用性/可讀性這塊 FreeRTOS 應(yīng)該說是最差,奇葩的匈牙利命名法,代碼實現(xiàn)用了很多宏,可讀性非常差。ucos 可讀性還可以,注釋也很全。這塊做的比較好的是 RT-Thread ,它是類 Linux 的代碼風(fēng)格,面向?qū)ο蟮脑O(shè)計模式,代碼簡潔易懂。在保證了體積(最小 ROM:3K RAM:1.5K)的同時,還借鑒了 Linux 的設(shè)備驅(qū)動框架、虛擬文件系統(tǒng)、Shell 等功能,設(shè)計更加優(yōu)雅。
3、 組件豐富性RT-Thread 比起傳統(tǒng) UCOS、FreeRTOS 不僅僅在基礎(chǔ)功能上多而全,多達(dá) 50 個以上的可重用軟件組件,還有很多物聯(lián)網(wǎng)組件,對于物聯(lián)網(wǎng)產(chǎn)品幾乎做到開箱即用。RT-Thread 還可以運(yùn)行 Python、JavaScript、Lua 這些高級語言的腳本,進(jìn)一步降低開發(fā)難度。
4、 開發(fā)資料這塊 ucos 做的最好,還有配套相關(guān)的書籍,F(xiàn)reeRTOS 屬于后起之秀,網(wǎng)上也有很多相關(guān)資料。RT-Thread 這塊之前還是略顯薄弱的,不過現(xiàn)在 RT-Thread 對這塊非常重視,最直觀的可以看到官網(wǎng)上的應(yīng)用筆記越來越多了,還有一些配套教學(xué)視頻。5、版權(quán)
ucos 商業(yè)是要收費(fèi)的,F(xiàn)reeRTOS 和 RT-Thread 版權(quán)都很寬松,特別是RT-Thread剛剛使用了Apache許可協(xié)議。
6、 社區(qū)生態(tài)這三款 RTOS 的社區(qū)都比較活躍,現(xiàn)在可以感覺到 ucos 慢慢的用的人越來越少了,RT-Thread 和 FreeRTOS 用的人都在增多。RT-Thread 也是開發(fā)者最多的國產(chǎn) RTOS,并且還擁有國內(nèi)最大的嵌入式開源軟件社區(qū)。
來源:網(wǎng)絡(luò)

版權(quán)歸原作者所有,如有侵權(quán),請聯(lián)系刪除。

21ic電子網(wǎng)

掃描二維碼,關(guān)注更多精彩內(nèi)容

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實性等。需要轉(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)中有升 落實提質(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)閉
關(guān)閉