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

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

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

嵌入式軟件兼容性:關(guān)鍵挑戰(zhàn)與解決之道

Linux大陸 ? 來源:csdn ? 2024-02-28 10:19 ? 次閱讀

嵌入式項(xiàng)目中,軟件是一個(gè)不斷迭代的過程,需要考慮各種兼容性。之前我們的項(xiàng)目,因?yàn)檫@方面考慮得比較少,導(dǎo)致項(xiàng)目中后期開發(fā)起來很被動。

項(xiàng)目系統(tǒng)總體設(shè)計(jì)階段,應(yīng)盡可能地考慮到未來可以遇見的情況,覆蓋到盡可能多的業(yè)務(wù)擴(kuò)展。項(xiàng)目雖然分階段開發(fā),各個(gè)階段完成的功能都不一樣,總體設(shè)計(jì)要指向最終的需求。

數(shù)據(jù)兼容性

1、協(xié)議制定

制定的協(xié)議要滿足整個(gè)項(xiàng)目所有數(shù)據(jù)的交互。

比如:

70d6cfe0-d5d3-11ee-a297-92fbcf53809c.png

這里的 ID 設(shè)置為 1 個(gè)字節(jié),可能有一定的風(fēng)險(xiǎn)。后面功能加著加著,可能 1 個(gè)字節(jié)的 ID 滿足不了,就得改協(xié)議。盡管可能滿足了某個(gè)項(xiàng)目的需求,但萬一之后其它項(xiàng)目也用了這一套代碼,但是 1 個(gè)字節(jié)的 ID 滿足不了,又得改代碼。這里設(shè)置 2 字節(jié)可能會好一點(diǎn),基本上能滿足絕大部分情況的使用。

不一定為了覆蓋范圍更廣而設(shè)置 4 字節(jié),這樣可能有點(diǎn)冗余。很多情況都有一個(gè)平衡點(diǎn),需要自己權(quán)衡。

Length字段只設(shè)置了 1 個(gè)字節(jié),可能也有一定的奉獻(xiàn)。后面功能中如果有發(fā)較大的數(shù)據(jù),可能要分好多包發(fā),原本可以發(fā)得很快,被這里限制死了。到時(shí)候想要提速,就得改協(xié)議。

之前項(xiàng)目里,幾塊板間的通信都用同一套協(xié)議。但后期發(fā)現(xiàn)該協(xié)議滿足不了新需求,但為了不影響到前面的數(shù)據(jù),又搞了一套協(xié)議。導(dǎo)致項(xiàng)目里有兩套差不多一樣的協(xié)議處理代碼。

協(xié)議應(yīng)該是項(xiàng)目一開始考慮好、制定好,整個(gè)項(xiàng)目開發(fā)期間,都不應(yīng)該再做改動。

2、數(shù)據(jù)添加

后面新增的數(shù)據(jù),不應(yīng)該插入現(xiàn)有的數(shù)據(jù)中,應(yīng)該單獨(dú)增加一個(gè)數(shù)據(jù)ID。

比如:

現(xiàn)有的數(shù)據(jù)中,有一條數(shù)據(jù)叫做設(shè)備信息的數(shù)據(jù),設(shè)備信息里包含了:設(shè)備IP、設(shè)備Mac。這個(gè)數(shù)據(jù)會顯示在手機(jī)APP上。對應(yīng)的 C 語言代碼:

#defineMSG_ID_DEV_INFO0x0001

typedefstruct_dev_info
{
chardev_ip[IP_MAX_LEN];
chardev_mac[MAC_MAX_LEN];
}dev_info_t;

假如后面需要再顯示一個(gè)設(shè)備的sn,這個(gè)數(shù)據(jù)我們應(yīng)該加在哪里?

如果是項(xiàng)目前中期,這時(shí)候還是在開發(fā)階段,我們可以隨意修改。因?yàn)樵O(shè)備sn也是設(shè)備信息的一部分,可以直接在設(shè)備信息這個(gè)數(shù)據(jù)里添加會比較合理:

#defineMSG_ID_DEV_INFO0x0001

typedefstruct_dev_info
{
chardev_ip[IP_MAX_LEN];
chardev_mac[MAC_MAX_LEN];
chardev_sn[SN_MAX_LEN];
}dev_info_t;

如果是產(chǎn)品已經(jīng)在市場上流通,這時(shí)候這么加的話,軟件兼容性就不太好。因?yàn)榧偃缒愕氖謾C(jī)APP版本與設(shè)備版本不匹配,原有的設(shè)備IP及設(shè)備MAC這兩個(gè)設(shè)備信息可能都顯示不出來,因?yàn)槲覀冞@么一改,破壞了原有的數(shù)據(jù)結(jié)構(gòu),而手機(jī)APP按照原來的數(shù)據(jù)來做解析的,會解析不過。

這時(shí)候可以這么來加:

#defineMSG_ID_DEV_INFO0x0001
#defineMSG_ID_DEV_SN0x0002

typedefstruct_dev_info
{
chardev_ip[IP_MAX_LEN];
chardev_mac[MAC_MAX_LEN];
}dev_info_t;

typedefstruct_dev_sn
{
chardev_sn[SN_MAX_LEN];
}dev_sn_t;

這樣,哪怕手機(jī)APP版本與設(shè)備版本沒有對應(yīng)上,原來的數(shù)據(jù)還是能正常顯示的。當(dāng)然,最好的情況當(dāng)然是在開發(fā)階段就合理地設(shè)計(jì)好。不然,像這種情況,只能犧牲一些程序可讀性來換取程序兼容性了。這會讓后面看代碼的人覺得很奇怪,你這個(gè)sn不也是數(shù)據(jù)設(shè)備信息嗎,怎么還單獨(dú)給一個(gè)ID。后面接手這個(gè)代碼的人可能就會把這一塊代碼給改了。

溫馨提示:在沒有完全弄懂維護(hù)項(xiàng)目的代碼為什么這么實(shí)現(xiàn)的情況下,能正常在跑的程序還是別亂動得好,哪怕你覺得這是屎山代碼。否則可能會出大問題。要么等到軟件重構(gòu)時(shí)再修改,要么就繼續(xù)打補(bǔ)丁。

3、數(shù)據(jù)刪除

如果是刪除本模塊內(nèi)部自己使用的數(shù)據(jù),你想怎么刪就怎么刪。

如果是刪除與其它模塊進(jìn)行交互的數(shù)據(jù),這就不能這么隨意了。比如,請求、應(yīng)答的方式。應(yīng)答端給請求端返回的數(shù)據(jù)是不能隨意刪的,如果要刪,一定要確保請求端已經(jīng)沒有請求數(shù)據(jù)的需求,并且已經(jīng)去掉相關(guān)代碼時(shí),這時(shí)候應(yīng)答端才去刪數(shù)據(jù),否則還是留著吧。

4、數(shù)據(jù)修改

其實(shí)數(shù)據(jù)定了,為了保證軟件兼容性,應(yīng)該是要禁止修改的。

如果一定要修改,可以先增加一條新數(shù)據(jù),后面慢慢切為新數(shù)據(jù)、刪除舊數(shù)據(jù)。

接口兼容性

正在使用的接口,應(yīng)該盡量不要修改。如果要修改,一定不要影響之前的功能。

之前就有遇到類似的情況。舉個(gè)例子:

typedefenum_sys_status
{
SYS_STATUS_IDLE,
SYS_STATUS_RUNNING,
SYS_STATUS_STOP,
}sys_status_t;

staticsys_status_tg_sys_status;

sys_status_tget_sys_status(void)
{
returng_sys_status;
}

這里的系統(tǒng)狀態(tài)是要顯示在手機(jī)APP上的,不同的狀態(tài)顯示不同的圖標(biāo)。后面要新增一個(gè)狀態(tài),結(jié)果數(shù)據(jù)提供者這么改

typedefenum_sys_status
{
SYS_STATUS_IDLE,
SYS_STATUS_NEW_STATUS,
SYS_STATUS_RUNNING,
SYS_STATUS_STOP,
}sys_status_t;

staticsys_status_tg_sys_status;

sys_status_tget_sys_status(void)
{
returng_sys_status;
}

接口提供者把新增的數(shù)據(jù)插入了中間,影響了枚舉原有的順序。結(jié)果手機(jī)APP上圖標(biāo)顯示亂了。

影響到接口的修改,要保證原有的數(shù)據(jù)不受影響。

系統(tǒng)兼容性

在軟件升級過程中,需要考慮軟件所依賴的其他系統(tǒng)組件是否發(fā)生變化,以確保升級后軟件能夠正常運(yùn)行,不會影響其他系統(tǒng)組件的正常運(yùn)行。如果其他系統(tǒng)組件發(fā)生變化,則需要進(jìn)行相關(guān)測試和文檔更新,以確保整個(gè)系統(tǒng)能夠正常運(yùn)行。

另外隨著項(xiàng)目的迭代,這一套代碼有可能運(yùn)行于不同的系統(tǒng)不同的芯片平臺。

比如,我們嵌入式Linux項(xiàng)目,有些項(xiàng)目里會用到一些第三方庫,這時(shí)候可能會編譯成動態(tài)庫的形式。要考慮升級的時(shí)候能不能升級動態(tài)庫。如果不能,就得把依賴的庫一起編譯到可執(zhí)行程序里。

另外,如果使用動態(tài)庫,之后產(chǎn)品軟硬件迭代換了一個(gè)芯片平臺的話,我們就需要重新交叉編譯一次所依賴的庫。如果為了保證這一塊的兼容性,也可以考慮把所依賴的庫與用戶代碼一起編譯。

當(dāng)然,這個(gè)根據(jù)實(shí)際情況進(jìn)行權(quán)衡取舍。如果依賴的庫很多,一起編譯到可執(zhí)行程序里,導(dǎo)致可執(zhí)行程序很大,到時(shí)候更新也不好更新。

功能兼容性

涉及到功能的添加的,盡量不要影響到之前已開發(fā)的功能。不然也會增加用戶對產(chǎn)品的學(xué)習(xí)成本。比如某些指示燈在前一個(gè)版本的快閃、慢閃代表什么意思,這個(gè)在之后就盡量不要去修改了,不然用戶又得重新理解。

性能兼容性

在軟件升級過程中,需要考慮軟件的性能是否發(fā)生變化,以確保升級后軟件的性能仍然能夠滿足用戶需求。如果軟件的性能發(fā)生變化,則需要進(jìn)行相關(guān)測試和優(yōu)化,以確保軟件能夠正常運(yùn)行,并且能夠滿足用戶的性能需求。

比如,原來正常升級需要3分鐘,某個(gè)版本之后升級變成了6分鐘,升級效率變差了。

安全兼容性

在軟件升級過程中,需要考慮軟件的安全性是否得到加強(qiáng),以確保升級后軟件的安全性能夠得到保障,不會出現(xiàn)新的安全風(fēng)險(xiǎn)。如果軟件的安全性得到加強(qiáng),則需要進(jìn)行相關(guān)測試和文檔更新,以確保軟件能夠正常運(yùn)行,并且能夠保障用戶的安全。

審核編輯:黃飛

聲明:本文內(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)注

    4

    文章

    240

    瀏覽量

    26670

原文標(biāo)題:不容忽視的嵌入式軟件兼容性問題

文章出處:【微信號:Linux大陸,微信公眾號:Linux大陸】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    談?wù)?b class='flag-5'>嵌入式軟件兼容性

    嵌入式項(xiàng)目中,軟件是一個(gè)不斷迭代的過程,需要考慮各種兼容性。之前我們的項(xiàng)目,因?yàn)檫@方面考慮得比較少,導(dǎo)致項(xiàng)目中后期開發(fā)起來很被動。
    發(fā)表于 06-27 11:08 ?526次閱讀
    談?wù)?b class='flag-5'>嵌入式</b><b class='flag-5'>軟件</b>的<b class='flag-5'>兼容性</b>

    物聯(lián)網(wǎng)嵌入式軟件設(shè)計(jì)的挑戰(zhàn)及應(yīng)對之道

    本文將討論物聯(lián)網(wǎng)設(shè)計(jì)領(lǐng)域中的主要軟件挑戰(zhàn),并介紹正確的工具鏈選擇如何有助于因應(yīng)這些嵌入式設(shè)計(jì)挑戰(zhàn)。文中主要關(guān)注于物聯(lián)網(wǎng)軟件生態(tài)系統(tǒng)中的三大
    發(fā)表于 11-16 10:36 ?2643次閱讀

    C語言嵌入式編程修煉之道

    C語言嵌入式編程修煉之道 不同于一般形式的軟件編程,嵌入式系統(tǒng)編程建立在特定的硬件平臺上,勢必要求其編程語言具備較強(qiáng)的硬件直接操作能力。無疑,匯編語言具備這樣的特質(zhì)。但是,歸
    發(fā)表于 10-31 14:09

    嵌入式修煉之道

    嵌入式修煉之道
    發(fā)表于 05-21 23:06

    嵌入式C語言進(jìn)階之道

    嵌入式C語言進(jìn)階之道
    發(fā)表于 08-20 16:02

    C言嵌入式系統(tǒng)修練之道

    C言嵌入式系統(tǒng)修練之道--背景編,是學(xué)習(xí)嵌入式系統(tǒng)設(shè)計(jì)的技術(shù)參考文件,對于學(xué)習(xí)嵌入式的童鞋們可以有幫助。{:1:}{:1:}
    發(fā)表于 04-09 15:32

    如何應(yīng)對機(jī)器人設(shè)計(jì)開發(fā)中的挑戰(zhàn)

    Moon博士強(qiáng)調(diào)了對于集成的嵌入式系統(tǒng)以及直觀開發(fā)軟件的需求。認(rèn)識到這些挑戰(zhàn),世界各地的業(yè)內(nèi)人士都在努力尋求這些挑戰(zhàn)
    發(fā)表于 07-31 07:17

    嵌入式C語言的修煉之道

    軟件結(jié)構(gòu)很重要!嵌入式C語言修煉之道
    發(fā)表于 05-05 12:39

    ARM編譯器for Embedded Version 6.20移植和兼容性指南

    Arm?編譯器嵌入式遷移和兼容性指南為從舊版本的Arm編譯器遷移到Arm編譯器嵌入式6的用戶提供遷移和兼容性信息。
    發(fā)表于 08-10 07:17

    淺論嵌入式系統(tǒng)離線測試

    隨著嵌入式系統(tǒng)的發(fā)展,迫切需要在嵌入式系統(tǒng)開發(fā)階段對嵌入式系統(tǒng)進(jìn)行離線測試與分析,以保證系統(tǒng)的軟件應(yīng)用程序、硬件具有兼容性、高可靠
    發(fā)表于 09-26 14:59 ?872次閱讀

    C語言的嵌入式系統(tǒng)編程修煉之道

    C語言的嵌入式系統(tǒng)編程修煉之道
    發(fā)表于 10-24 08:36 ?29次下載
    C語言的<b class='flag-5'>嵌入式</b>系統(tǒng)編程修煉<b class='flag-5'>之道</b>

    嵌入式產(chǎn)品的研發(fā)之道

    嵌入式產(chǎn)品的研發(fā)之道
    發(fā)表于 10-24 13:45 ?9次下載
    <b class='flag-5'>嵌入式</b>產(chǎn)品的研發(fā)<b class='flag-5'>之道</b>

    嵌入式軟件是什么意思_嵌入式軟件的分類有哪些

    本文首先闡述了嵌入式軟件的概念,其次介紹了嵌入式軟件的特征,最后介紹了嵌入式軟件的分類。
    發(fā)表于 08-31 15:54 ?1.6w次閱讀

    電源噪聲測量的挑戰(zhàn)解決之道

    電源噪聲測量的挑戰(zhàn)解決之道(新型電源技術(shù)論文)-電源噪聲與紋波是工程師經(jīng)常遇到且容易混淆的兩個(gè)概念,盡管是非常普及的測試項(xiàng)目,但是還沒有國 際協(xié)會和標(biāo)準(zhǔn)組織定義如何測量電源的電源紋波和噪聲。
    發(fā)表于 09-29 16:11 ?11次下載
    電源噪聲測量的<b class='flag-5'>挑戰(zhàn)</b>及<b class='flag-5'>解決之道</b>

    嵌入式項(xiàng)目中的軟件數(shù)據(jù)兼容性

    大家好,我是雜燴君。 嵌入式項(xiàng)目中,軟件是一個(gè)不斷迭代的過程,需要考慮各種兼容性。之前我們的項(xiàng)目,因?yàn)檫@方面考慮得比較少,導(dǎo)致項(xiàng)目中后期開發(fā)起來很被動。 項(xiàng)目系統(tǒng)總體設(shè)計(jì)階段,應(yīng)盡可能地考慮到未來
    的頭像 發(fā)表于 06-22 11:38 ?630次閱讀
    <b class='flag-5'>嵌入式</b>項(xiàng)目中的<b class='flag-5'>軟件</b>數(shù)據(jù)<b class='flag-5'>兼容性</b>