最美情侣中文字幕电影,在线麻豆精品传媒,在线网站高清黄,久久黄色视频

歡迎光臨散文網(wǎng) 會員登陸 & 注冊

嵌入式開發(fā):你應(yīng)該抽象化你的RTOS嗎?

2023-08-08 17:05 作者:粵嵌科技  | 我要投稿

  現(xiàn)代嵌入式系統(tǒng)已經(jīng)成為復(fù)雜的計算設(shè)備,需要Linux或?qū)崟r操作系統(tǒng)(RTOS)來幫助嵌入式開發(fā)人員管理其實時約束。對于RTOS用戶來說,開發(fā)人員需要做出一個有趣的設(shè)計決策;你應(yīng)該將RTOS從應(yīng)用程序中抽象出來還是解耦?

  不抽象RTOS的理由

  對于上面的問題,一個流行的答案是團隊不要抽象他們的RTOS。相反,RTOS成為整個應(yīng)用程序的核心組件。將應(yīng)用程序與RTOS緊密耦合有很多好處。

  首先,大多數(shù)抽象層都是為了滿足最低標(biāo)準(zhǔn)的特性而編寫的。這意味著如果你使用一個抽象層,并且只想遵循它所提供的特性,你可能會失去RTOS的一些功能。每臺RTOS都有獨特的功能,旨在應(yīng)對特定細分市場的挑戰(zhàn)。雖然你會發(fā)現(xiàn)創(chuàng)建任務(wù)、隊列等標(biāo)準(zhǔn)功能,但你可能不會發(fā)現(xiàn)內(nèi)存保護單元的抽象、與Arm TrustZone的集成或其他功能。

  接下來,你可能會發(fā)現(xiàn)使用抽象層會降低系統(tǒng)性能。今天的編譯器一般足夠好,可以進行適當(dāng)?shù)膬?yōu)化;但是,額外的調(diào)用和設(shè)置可能會占用額外的時鐘周期和內(nèi)存。

  最后,調(diào)試和故障排除會變得更加復(fù)雜。如果你通過抽象層與RTOS進行交互,并且出現(xiàn)了問題,那么你將被從細節(jié)中抽象出來。直接使用RTOS可以為嵌入式開發(fā)人員提供更好的工具和更大的可見性來解決問題。

  抽象你的RTOS的理由

  今天開發(fā)的許多嵌入式應(yīng)用程序都是在這樣的期望下創(chuàng)建的,即在十年或更長的時間內(nèi),核心代碼將會生成多種產(chǎn)品。產(chǎn)品在領(lǐng)域中活躍的時間也差不多,開發(fā)人員在設(shè)計和實現(xiàn)他們的系統(tǒng)時必須考慮到變化。RTOS解決方案來來去去。支持時好時壞。如果你想讓你的代碼經(jīng)受住時間的考驗,你的應(yīng)用程序不能寫得對你的RTOS有很強的依賴性。RTOS必須被抽象化。抽象RTOS有很多好處。

  首先,抽象層使得在短時間內(nèi)更改RTOS解決方案變得更加容易。你可能會問,“我為什么要改變我的RTOS?”,更好的解決方案可能會出現(xiàn),或者RTOS在所需的應(yīng)用領(lǐng)域可能會出現(xiàn)問題。也許嵌入式開發(fā)開發(fā)人員的流失會導(dǎo)致團隊不具備特定RTOS的經(jīng)驗,所以改變是不可避免的。有了抽象層,你可以通過對單個文件進行更改來更改RTOS,而不是更新代碼庫中的幾乎每個模塊。

  接下來,我們可以從另一個角度來看前面的原因。抽象層將你的應(yīng)用程序從RTOS中分離出來。消除應(yīng)用程序?qū)TOS的依賴使你的代碼更具可重用性和可移植性。我們都聽說過可靠的原則,其中之一就是利用依賴倒置原則。你應(yīng)該希望依賴于接口,這樣你就可以打破耦合。

  最后,RTOS的抽象層可以簡化與RTOS的交互。抽象層通常包含許多RTOSs支持的標(biāo)準(zhǔn)特性的子集。例如,CMSIS-RTOSsv2提供了一個抽象層,芯片供應(yīng)商通常使用它來支持多個RTOS。如果你檢查CMSIS-RTOSv2中包含的子集,以及幾個常見RTOS(如FreeRTOS、AzureRTOS和澤法)的API集,你會發(fā)現(xiàn)它們的API包含一些共同的元素,但卻完全不同。簡化的抽象使得開發(fā)人員更容易以一種通用的方式與各種RTOS進行交互。

  

  結(jié)論

  你應(yīng)該抽象你的RTOS嗎?看情況!每個項目和每個嵌入式開發(fā)團隊都有不同的目標(biāo)和需求,用來滿足客戶的需求。我建議當(dāng)你開始下一個項目時,仔細考慮你是否真的希望你的應(yīng)用程序與你的RTOS緊密耦合。你可能會發(fā)現(xiàn)這是一個令人愉快的解決方案,或者你可能會發(fā)現(xiàn)是時候使用操作系統(tǒng)抽象層(OSAL)并使你的代碼更加可移植和可重用了。

  嵌入式開發(fā):你應(yīng)該抽象化你的RTOS嗎?

  現(xiàn)代嵌入式系統(tǒng)已經(jīng)成為復(fù)雜的計算設(shè)備,需要Linux或?qū)崟r操作系統(tǒng)(RTOS)來幫助嵌入式開發(fā)人員管理其實時約束。對于RTOS用戶來說,開發(fā)人員需要做出一個有趣的設(shè)計決策;你應(yīng)該將RTOS從應(yīng)用程序中抽象出來還是解耦?

  不抽象RTOS的理由

  對于上面的問題,一個流行的答案是團隊不要抽象他們的RTOS。相反,RTOS成為整個應(yīng)用程序的核心組件。將應(yīng)用程序與RTOS緊密耦合有很多好處。

  首先,大多數(shù)抽象層都是為了滿足最低標(biāo)準(zhǔn)的特性而編寫的。這意味著如果你使用一個抽象層,并且只想遵循它所提供的特性,你可能會失去RTOS的一些功能。每臺RTOS都有獨特的功能,旨在應(yīng)對特定細分市場的挑戰(zhàn)。雖然你會發(fā)現(xiàn)創(chuàng)建任務(wù)、隊列等標(biāo)準(zhǔn)功能,但你可能不會發(fā)現(xiàn)內(nèi)存保護單元的抽象、與Arm TrustZone的集成或其他功能。

  接下來,你可能會發(fā)現(xiàn)使用抽象層會降低系統(tǒng)性能。今天的編譯器一般足夠好,可以進行適當(dāng)?shù)膬?yōu)化;但是,額外的調(diào)用和設(shè)置可能會占用額外的時鐘周期和內(nèi)存。

  最后,調(diào)試和故障排除會變得更加復(fù)雜。如果你通過抽象層與RTOS進行交互,并且出現(xiàn)了問題,那么你將被從細節(jié)中抽象出來。直接使用RTOS可以為嵌入式開發(fā)人員提供更好的工具和更大的可見性來解決問題。

  抽象你的RTOS的理由

  今天開發(fā)的許多嵌入式應(yīng)用程序都是在這樣的期望下創(chuàng)建的,即在十年或更長的時間內(nèi),核心代碼將會生成多種產(chǎn)品。產(chǎn)品在領(lǐng)域中活躍的時間也差不多,開發(fā)人員在設(shè)計和實現(xiàn)他們的系統(tǒng)時必須考慮到變化。RTOS解決方案來來去去。支持時好時壞。如果你想讓你的代碼經(jīng)受住時間的考驗,你的應(yīng)用程序不能寫得對你的RTOS有很強的依賴性。RTOS必須被抽象化。抽象RTOS有很多好處。

  首先,抽象層使得在短時間內(nèi)更改RTOS解決方案變得更加容易。你可能會問,“我為什么要改變我的RTOS?”,更好的解決方案可能會出現(xiàn),或者RTOS在所需的應(yīng)用領(lǐng)域可能會出現(xiàn)問題。也許嵌入式開發(fā)開發(fā)人員的流失會導(dǎo)致團隊不具備特定RTOS的經(jīng)驗,所以改變是不可避免的。有了抽象層,你可以通過對單個文件進行更改來更改RTOS,而不是更新代碼庫中的幾乎每個模塊。

  接下來,我們可以從另一個角度來看前面的原因。抽象層將你的應(yīng)用程序從RTOS中分離出來。消除應(yīng)用程序?qū)TOS的依賴使你的代碼更具可重用性和可移植性。我們都聽說過可靠的原則,其中之一就是利用依賴倒置原則。你應(yīng)該希望依賴于接口,這樣你就可以打破耦合。

  最后,RTOS的抽象層可以簡化與RTOS的交互。抽象層通常包含許多RTOSs支持的標(biāo)準(zhǔn)特性的子集。例如,CMSIS-RTOSsv2提供了一個抽象層,芯片供應(yīng)商通常使用它來支持多個RTOS。如果你檢查CMSIS-RTOSv2中包含的子集,以及幾個常見RTOS(如FreeRTOS、AzureRTOS和澤法)的API集,你會發(fā)現(xiàn)它們的API包含一些共同的元素,但卻完全不同。簡化的抽象使得開發(fā)人員更容易以一種通用的方式與各種RTOS進行交互。

  

  結(jié)論

  你應(yīng)該抽象你的RTOS嗎?看情況!每個項目和每個嵌入式開發(fā)團隊都有不同的目標(biāo)和需求,用來滿足客戶的需求。我建議當(dāng)你開始下一個項目時,仔細考慮你是否真的希望你的應(yīng)用程序與你的RTOS緊密耦合。你可能會發(fā)現(xiàn)這是一個令人愉快的解決方案,或者你可能會發(fā)現(xiàn)是時候使用操作系統(tǒng)抽象層(OSAL)并使你的代碼更加可移植和可重用了?! ∏度胧介_發(fā):你應(yīng)該抽象化你的RTOS嗎?

  現(xiàn)代嵌入式系統(tǒng)已經(jīng)成為復(fù)雜的計算設(shè)備,需要Linux或?qū)崟r操作系統(tǒng)(RTOS)來幫助嵌入式開發(fā)人員管理其實時約束。對于RTOS用戶來說,開發(fā)人員需要做出一個有趣的設(shè)計決策;你應(yīng)該將RTOS從應(yīng)用程序中抽象出來還是解耦?

  不抽象RTOS的理由

  對于上面的問題,一個流行的答案是團隊不要抽象他們的RTOS。相反,RTOS成為整個應(yīng)用程序的核心組件。將應(yīng)用程序與RTOS緊密耦合有很多好處。

  首先,大多數(shù)抽象層都是為了滿足最低標(biāo)準(zhǔn)的特性而編寫的。這意味著如果你使用一個抽象層,并且只想遵循它所提供的特性,你可能會失去RTOS的一些功能。每臺RTOS都有獨特的功能,旨在應(yīng)對特定細分市場的挑戰(zhàn)。雖然你會發(fā)現(xiàn)創(chuàng)建任務(wù)、隊列等標(biāo)準(zhǔn)功能,但你可能不會發(fā)現(xiàn)內(nèi)存保護單元的抽象、與Arm TrustZone的集成或其他功能。

  接下來,你可能會發(fā)現(xiàn)使用抽象層會降低系統(tǒng)性能。今天的編譯器一般足夠好,可以進行適當(dāng)?shù)膬?yōu)化;但是,額外的調(diào)用和設(shè)置可能會占用額外的時鐘周期和內(nèi)存。

  最后,調(diào)試和故障排除會變得更加復(fù)雜。如果你通過抽象層與RTOS進行交互,并且出現(xiàn)了問題,那么你將被從細節(jié)中抽象出來。直接使用RTOS可以為嵌入式開發(fā)人員提供更好的工具和更大的可見性來解決問題。

  抽象你的RTOS的理由

  今天開發(fā)的許多嵌入式應(yīng)用程序都是在這樣的期望下創(chuàng)建的,即在十年或更長的時間內(nèi),核心代碼將會生成多種產(chǎn)品。產(chǎn)品在領(lǐng)域中活躍的時間也差不多,開發(fā)人員在設(shè)計和實現(xiàn)他們的系統(tǒng)時必須考慮到變化。RTOS解決方案來來去去。支持時好時壞。如果你想讓你的代碼經(jīng)受住時間的考驗,你的應(yīng)用程序不能寫得對你的RTOS有很強的依賴性。RTOS必須被抽象化。抽象RTOS有很多好處。

  首先,抽象層使得在短時間內(nèi)更改RTOS解決方案變得更加容易。你可能會問,“我為什么要改變我的RTOS?”,更好的解決方案可能會出現(xiàn),或者RTOS在所需的應(yīng)用領(lǐng)域可能會出現(xiàn)問題。也許嵌入式開發(fā)開發(fā)人員的流失會導(dǎo)致團隊不具備特定RTOS的經(jīng)驗,所以改變是不可避免的。有了抽象層,你可以通過對單個文件進行更改來更改RTOS,而不是更新代碼庫中的幾乎每個模塊。

  接下來,我們可以從另一個角度來看前面的原因。抽象層將你的應(yīng)用程序從RTOS中分離出來。消除應(yīng)用程序?qū)TOS的依賴使你的代碼更具可重用性和可移植性。我們都聽說過可靠的原則,其中之一就是利用依賴倒置原則。你應(yīng)該希望依賴于接口,這樣你就可以打破耦合。

  最后,RTOS的抽象層可以簡化與RTOS的交互。抽象層通常包含許多RTOSs支持的標(biāo)準(zhǔn)特性的子集。例如,CMSIS-RTOSsv2提供了一個抽象層,芯片供應(yīng)商通常使用它來支持多個RTOS。如果你檢查CMSIS-RTOSv2中包含的子集,以及幾個常見RTOS(如FreeRTOS、AzureRTOS和澤法)的API集,你會發(fā)現(xiàn)它們的API包含一些共同的元素,但卻完全不同。簡化的抽象使得開發(fā)人員更容易以一種通用的方式與各種RTOS進行交互。

  

  結(jié)論

  你應(yīng)該抽象你的RTOS嗎?看情況!每個項目和每個嵌入式開發(fā)團隊都有不同的目標(biāo)和需求,用來滿足客戶的需求。我建議當(dāng)你開始下一個項目時,仔細考慮你是否真的希望你的應(yīng)用程序與你的RTOS緊密耦合。你可能會發(fā)現(xiàn)這是一個令人愉快的解決方案,或者你可能會發(fā)現(xiàn)是時候使用操作系統(tǒng)抽象層(OSAL)并使你的代碼更加可移植和可重用了?! ∏度胧介_發(fā):你應(yīng)該抽象化你的RTOS嗎?

  現(xiàn)代嵌入式系統(tǒng)已經(jīng)成為復(fù)雜的計算設(shè)備,需要Linux或?qū)崟r操作系統(tǒng)(RTOS)來幫助嵌入式開發(fā)人員管理其實時約束。對于RTOS用戶來說,開發(fā)人員需要做出一個有趣的設(shè)計決策;你應(yīng)該將RTOS從應(yīng)用程序中抽象出來還是解耦?

  不抽象RTOS的理由

  對于上面的問題,一個流行的答案是團隊不要抽象他們的RTOS。相反,RTOS成為整個應(yīng)用程序的核心組件。將應(yīng)用程序與RTOS緊密耦合有很多好處。

  首先,大多數(shù)抽象層都是為了滿足最低標(biāo)準(zhǔn)的特性而編寫的。這意味著如果你使用一個抽象層,并且只想遵循它所提供的特性,你可能會失去RTOS的一些功能。每臺RTOS都有獨特的功能,旨在應(yīng)對特定細分市場的挑戰(zhàn)。雖然你會發(fā)現(xiàn)創(chuàng)建任務(wù)、隊列等標(biāo)準(zhǔn)功能,但你可能不會發(fā)現(xiàn)內(nèi)存保護單元的抽象、與Arm TrustZone的集成或其他功能。

  接下來,你可能會發(fā)現(xiàn)使用抽象層會降低系統(tǒng)性能。今天的編譯器一般足夠好,可以進行適當(dāng)?shù)膬?yōu)化;但是,額外的調(diào)用和設(shè)置可能會占用額外的時鐘周期和內(nèi)存。

  最后,調(diào)試和故障排除會變得更加復(fù)雜。如果你通過抽象層與RTOS進行交互,并且出現(xiàn)了問題,那么你將被從細節(jié)中抽象出來。直接使用RTOS可以為嵌入式開發(fā)人員提供更好的工具和更大的可見性來解決問題。

  抽象你的RTOS的理由

  今天開發(fā)的許多嵌入式應(yīng)用程序都是在這樣的期望下創(chuàng)建的,即在十年或更長的時間內(nèi),核心代碼將會生成多種產(chǎn)品。產(chǎn)品在領(lǐng)域中活躍的時間也差不多,開發(fā)人員在設(shè)計和實現(xiàn)他們的系統(tǒng)時必須考慮到變化。RTOS解決方案來來去去。支持時好時壞。如果你想讓你的代碼經(jīng)受住時間的考驗,你的應(yīng)用程序不能寫得對你的RTOS有很強的依賴性。RTOS必須被抽象化。抽象RTOS有很多好處。

  首先,抽象層使得在短時間內(nèi)更改RTOS解決方案變得更加容易。你可能會問,“我為什么要改變我的RTOS?”,更好的解決方案可能會出現(xiàn),或者RTOS在所需的應(yīng)用領(lǐng)域可能會出現(xiàn)問題。也許嵌入式開發(fā)開發(fā)人員的流失會導(dǎo)致團隊不具備特定RTOS的經(jīng)驗,所以改變是不可避免的。有了抽象層,你可以通過對單個文件進行更改來更改RTOS,而不是更新代碼庫中的幾乎每個模塊。

  接下來,我們可以從另一個角度來看前面的原因。抽象層將你的應(yīng)用程序從RTOS中分離出來。消除應(yīng)用程序?qū)TOS的依賴使你的代碼更具可重用性和可移植性。我們都聽說過可靠的原則,其中之一就是利用依賴倒置原則。你應(yīng)該希望依賴于接口,這樣你就可以打破耦合。

  最后,RTOS的抽象層可以簡化與RTOS的交互。抽象層通常包含許多RTOSs支持的標(biāo)準(zhǔn)特性的子集。例如,CMSIS-RTOSsv2提供了一個抽象層,芯片供應(yīng)商通常使用它來支持多個RTOS。如果你檢查CMSIS-RTOSv2中包含的子集,以及幾個常見RTOS(如FreeRTOS、AzureRTOS和澤法)的API集,你會發(fā)現(xiàn)它們的API包含一些共同的元素,但卻完全不同。簡化的抽象使得開發(fā)人員更容易以一種通用的方式與各種RTOS進行交互。

  

  結(jié)論

  你應(yīng)該抽象你的RTOS嗎?看情況!每個項目和每個嵌入式開發(fā)團隊都有不同的目標(biāo)和需求,用來滿足客戶的需求。我建議當(dāng)你開始下一個項目時,仔細考慮你是否真的希望你的應(yīng)用程序與你的RTOS緊密耦合。你可能會發(fā)現(xiàn)這是一個令人愉快的解決方案,或者你可能會發(fā)現(xiàn)是時候使用操作系統(tǒng)抽象層(OSAL)并使你的代碼更加可移植和可重用了。vvvv


嵌入式開發(fā):你應(yīng)該抽象化你的RTOS嗎?的評論 (共 條)

分享到微博請遵守國家法律
临汾市| 水城县| 石嘴山市| 荥经县| 大荔县| 安康市| 韩城市| 改则县| 威信县| 盐源县| 扶绥县| 广宁县| 香格里拉县| 调兵山市| 长海县| 额尔古纳市| 安福县| 临沭县| 新巴尔虎左旗| 前郭尔| 加查县| 宾川县| 东明县| 武强县| 千阳县| 西华县| 长子县| 牟定县| 茌平县| 安西县| 庆云县| 凤山市| 长葛市| 英吉沙县| 宁明县| 彩票| 义马市| 平舆县| 民勤县| 郎溪县| 砚山县|