在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

數據分包設計的考慮

Q4MP_gh_c472c21 ? 來源:最后一個bug ? 作者:最后一個bug ? 2022-05-12 14:54 ? 次閱讀

大家好,我是bug菌~前些天跟大家解釋了如下代碼:

		

offset=len/64+!!(len%64);

并且跟大家詳細聊了一下其中的!!操作,然而這段代碼的主要功能還是為了進行分包處理,既然是分包自然而然就會想到一種常用的分包處理方法,這也是本文的重點。

數據分包在嵌入式軟件開發中算是一種非常常見的處理,其主要原因還是硬件上的各種限制,不得已而為之,特別是在通信協議的定制過程中尤為常見。

1

傳輸限制

玩過各種通信協議的朋友都知道,像非常多的通信方式都是以數據幀的形式來進行傳遞,不同的通信方式因各方面的因素又存在一個最大傳輸字節數的限制,考慮到穩定性、容錯性等等對單次發送的數據長度進行限制,又或者所接收的設備其內存資源有限,不足以接收、處理過長的數據包。

zigbee這樣的物理層每幀最大只能傳輸127個字節,通過每層不斷的封包到應用層后每包才100個字節。當上層用戶協議的數據包過大,無法一次性傳輸,就只能分包或者分組下發,最終接收方組包后解析提取數據。

2

分包設計的考慮

有些朋友該說了,我就不喜歡搞大包發送,使用短包,然后通過不同的標識進行不同數據位的定義,簡單很多。

當然長包與短包并沒有本質上的區別,其目的都是傳輸數據,但在實踐的過程中還是會遇到居多處理上的區別:

數據的同步性方面:

比如當通信的設備轉速超了,同時報了一個故障碼,如果采用短包上傳,很可能故障碼和轉速位于不同的數據包中,當數據包丟包或許是亂序,就會導致當接收到故障碼的時候,此時超標的轉速值已經丟失或者延時等,有概率不能準確獲得故障時的超標轉速。

而使用長包,只需要發送方能夠保證打包的時候同步,那么接收方就可以同步獲得相應的數據。

通信協議設計自由度方面:

在設計協議的時候,長包會更加的自由,大多數情況都不需要考慮大數據傳輸的占位問題,甚至在編碼上直接copy結構體發送也是相當方便的。

3

計算包數問題

既然長包的設計相對比較方便。那分包處理是少不了的?

分包還不簡單?

要發100個字節的數據,每次只能發15個,那發送7包就可以了,直接編碼,代碼如下:

SendPack=SendNum/PackNum;
if(SendPack%PackNum)SendPack++;

這算是常規操作,如果覺得有點難度,還要多敲敲代碼。

一般用C語言比較久的朋友都想去簡化這種操作,畢竟實現一個簡單的功能需要兩行代碼,強迫癥,忍不了~

就有了本文開頭的!!處理方式,或者如下處理也是一樣的:


		

#include #definePackNum(total,single)(total/single+((total%single)?1:0)) intmain(void) { printf("packNum:%d ",PackNum(100,15)); printf("packNum:%d ",PackNum(150,15)); printf("packNum:%d ",PackNum(200,15)); printf("packNum:%d ",PackNum(5,15)); printf("hellobug~ "); return0; }

僅僅只是秀了一下C語言的幾個小技巧罷了,并沒有實質性的改善。

很明顯,本文的重點并不是介紹如上兩種辦法,而是如下更加高效的代碼:


		

PackNum=(total+(singleNum-1))/singleNum;

對于一些以往沒有使用的朋友或許有點懵,那bug菌這是嘮叨幾句:

該表達式主要是利用了取整的特性來達到+1的目的。

直接除單包個數,不能整除的情況,結果都會少1,比如10/6,應該是2包,而由于最終除法結果只能是1。

所以通過補償(singleNum - 1)后,結果就分兩種情況:

1、原本能夠整除的數,補償后無法整除,結果與之前一致;

2、原本不能夠整除的數,其余數必然在【1~(singleNum- 1)】之間,所以補償以后,其余數范圍在【singleNum~(singleNum+ singleNum- 2),則其結果為整除部分+1。

與我們分包個數是一致的,相當巧妙。

4

擴展

這種方法不僅僅只是用于通信的分組中,把思維進一步泛化。

只要是類似分組的處理都可以使用該算法

比如內存的分區,flash的設計上都是一個扇區一個扇區的分布。

現在想分配整數個扇形區域用于存儲某些數據,每一個扇區512個字節,存儲2000個字節的數據,該分配幾個扇區?

我相信你已經有答案了~

審核編輯 :李倩

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 數據
    +關注

    關注

    8

    文章

    7122

    瀏覽量

    89349
  • 數據包
    +關注

    關注

    0

    文章

    266

    瀏覽量

    24435
  • 代碼
    +關注

    關注

    30

    文章

    4816

    瀏覽量

    68863

原文標題:談談數據分包及相關小技巧

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    選擇數據采集器時需要考慮的因素

    在選擇數據采集器時,需要考慮以下關鍵因素,以確保所選設備能夠滿足特定應用需求并具有良好的性能和可靠性: 采集需求 : 數據類型和數量 :確定需要采集的數據類型(如溫度、濕度、壓力、位移
    的頭像 發表于 11-28 16:02 ?416次閱讀

    socket編程的安全性考慮

    在Socket編程中,安全性是一個至關重要的考慮因素。以下是一些關鍵的安全性考慮和措施: 1. 數據加密 使用TLS/SSL協議 :TLS/SSL(傳輸層安全性/安全套接層)是網絡安全中最常用的協議
    的頭像 發表于 11-01 16:46 ?318次閱讀

    BiCMOS ICs供電的考慮因素

    電子發燒友網站提供《BiCMOS ICs供電的考慮因素.pdf》資料免費下載
    發表于 10-23 09:34 ?0次下載
    BiCMOS ICs供電的<b class='flag-5'>考慮</b>因素

    字節跳動考慮在泰國新建數據中心

    據知情人士透露,字節跳動旗下的BytePlus正在積極考慮于明年在泰國設立一個全新的數據中心。這一舉措旨在進一步拓展公司在云計算和人工智能服務領域的全球布局。
    的頭像 發表于 10-22 17:05 ?322次閱讀

    高速ADC與FPGA的LVDS數據接口中避免時序誤差的設計考慮

    電子發燒友網站提供《高速ADC與FPGA的LVDS數據接口中避免時序誤差的設計考慮.pdf》資料免費下載
    發表于 10-15 09:50 ?5次下載
    高速ADC與FPGA的LVDS<b class='flag-5'>數據</b>接口中避免時序誤差的設計<b class='flag-5'>考慮</b>

    AM572x散熱考慮

    電子發燒友網站提供《AM572x散熱考慮.pdf》資料免費下載
    發表于 10-11 10:42 ?0次下載
    AM572x散熱<b class='flag-5'>考慮</b>

    高速電路PCB的EMC設計考慮

    電子發燒友網站提供《高速電路PCB的EMC設計考慮.pdf》資料免費下載
    發表于 09-21 11:50 ?5次下載

    DLPC910的datasheet中未看到pindelay數據,DLPC910和DMD之間的LVDS總線是否要考慮pindelay的影響?

    如標題所述,DLPC910的datasheet中未看到pindelay數據,DLPC910和DMD之間的LVDS總線是否要考慮pindelay的影響
    發表于 08-16 06:18

    ESP8266 RTOS SDK中Lwip自動分包及重組的問題求解

    數據包自動分包和重組,但是實際上我修改之后仍然無效,請問是不是還有其他宏需要修改?或者lwip本身有限制?
    發表于 07-10 08:12

    esp32如何接收1M以上的數據

    手里有1塊ESP32_WROVER 模組 ,服務器發送不定長數據可能最大會到1M-2M,我不太清楚怎么處理,目前使用recv接收1K左右的數據正常,希望有這方面的思路 ,可以使用PSRAM直接接收還是分包接收?
    發表于 06-21 14:56

    ESP32 BLE使用nimble協議棧怎樣才能發送超過20個字節的數據

    我在使用藍牙傳送傳感器數據,目前只能發送20個字節大小的數據包,請問大家是如何實現發送大于20字節的數據包的。我想嘗試將數據分包發送,但是
    發表于 06-17 07:18

    比亞迪出席2024年泰國曼谷工業分包展覽會

    2024年5月15日至18日,比亞迪集團采購處及泰國分公司代表出席了泰國曼谷工業分包展覽會(SUBCON Thailand 2024),彰顯了比亞迪在區域市場的深入拓展和對創新制造業合作的堅定承諾。
    的頭像 發表于 05-21 09:36 ?389次閱讀
    比亞迪出席2024年泰國曼谷工業<b class='flag-5'>分包</b>展覽會

    ESP32 基于ESP-IDF5.1.2 使用WIFI_AP_UDP發送數據時報錯 errno=12

    使用ESP32做無線傳輸,發送一幀圖像數據,進行分包,每次發送14300字節,大概率出現丟失最后一包,并伴隨sendto報錯信息,errno=12(Not enough space 空間不夠)
    發表于 05-07 16:34

    stm32f746g如何使用usb一次性發送一包超過1.5M的數據

    目前我正在用disco stm32f746g的板子通過高速usb給上位機傳輸數據,因為數據量比較大,所以一包數據就超過1.5M。上位機是一個很多年前寫的成熟版本,無法更改。高速usb的緩存達不到1.5M,所以如何
    發表于 03-13 08:29

    OLED設備公司DMS最近對二級分包商A公司提起訴訟

    WitDisplay消息,OLED設備公司DMS最近對二級分包商A公司提起訴訟,要求支付150億韓元(8100萬元人民幣)的過度延誤賠償。
    的頭像 發表于 02-29 15:40 ?754次閱讀
    主站蜘蛛池模板: 一级特一级特色生活片| 最好看免费中文字幕2018视频| 四虎影院.com| 在线视频毛片| 人人澡人人澡碰人人看软件| 日韩亚洲人成在线综合日本| 69xxxxtube日本免费| 婷婷在线网| 在线播放12p| 特级做a爰片毛片免费看一区| 色狠狠色综合久久8狠狠色| 中文字幕在线看精品乱码| 亚洲综合色丁香婷婷六月图片| 午色| 青草91| 韩国三级视频| www四虎| 欧美一级特黄aaaaaa在线看片| 亚洲午夜视频在线观看| 国产美女一级ba大片免色| 91正在播放| 97就要鲁就要鲁夜夜爽| 天天做天天爽| 天天摸天天躁天天添天天爽| 在线色片| 免费深夜视频| 啪啪免费视频| 国产尤物在线视频| 色五月丁香五月综合五月| 四虎国产精品免费入口| 男人都懂得网址| 久久久久久青草大香综合精品| 国产www色| 久久午夜国产片| 亚洲免费在线观看视频| 五月婷婷色综合| 久久综合久色欧美婷婷| 黄色www| 国产成人高清| 奇米奇米| 亚洲卡1卡2卡新区网站|