chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

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

數(shù)據(jù)分包設(shè)計(jì)的考慮

Q4MP_gh_c472c21 ? 來(lái)源:最后一個(gè)bug ? 作者:最后一個(gè)bug ? 2022-05-12 14:54 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

		

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

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

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

1

傳輸限制

玩過各種通信協(xié)議的朋友都知道,像非常多的通信方式都是以數(shù)據(jù)幀的形式來(lái)進(jìn)行傳遞,不同的通信方式因各方面的因素又存在一個(gè)最大傳輸字節(jié)數(shù)的限制,考慮到穩(wěn)定性、容錯(cuò)性等等對(duì)單次發(fā)送的數(shù)據(jù)長(zhǎng)度進(jìn)行限制,又或者所接收的設(shè)備其內(nèi)存資源有限,不足以接收、處理過長(zhǎng)的數(shù)據(jù)包。

zigbee這樣的物理層每幀最大只能傳輸127個(gè)字節(jié),通過每層不斷的封包到應(yīng)用層后每包才100個(gè)字節(jié)。當(dāng)上層用戶協(xié)議的數(shù)據(jù)包過大,無(wú)法一次性傳輸,就只能分包或者分組下發(fā),最終接收方組包后解析提取數(shù)據(jù)。

2

分包設(shè)計(jì)的考慮

有些朋友該說(shuō)了,我就不喜歡搞大包發(fā)送,使用短包,然后通過不同的標(biāo)識(shí)進(jìn)行不同數(shù)據(jù)位的定義,簡(jiǎn)單很多。

當(dāng)然長(zhǎng)包與短包并沒有本質(zhì)上的區(qū)別,其目的都是傳輸數(shù)據(jù),但在實(shí)踐的過程中還是會(huì)遇到居多處理上的區(qū)別:

數(shù)據(jù)的同步性方面:

比如當(dāng)通信的設(shè)備轉(zhuǎn)速超了,同時(shí)報(bào)了一個(gè)故障碼,如果采用短包上傳,很可能故障碼和轉(zhuǎn)速位于不同的數(shù)據(jù)包中,當(dāng)數(shù)據(jù)包丟包或許是亂序,就會(huì)導(dǎo)致當(dāng)接收到故障碼的時(shí)候,此時(shí)超標(biāo)的轉(zhuǎn)速值已經(jīng)丟失或者延時(shí)等,有概率不能準(zhǔn)確獲得故障時(shí)的超標(biāo)轉(zhuǎn)速。

而使用長(zhǎng)包,只需要發(fā)送方能夠保證打包的時(shí)候同步,那么接收方就可以同步獲得相應(yīng)的數(shù)據(jù)。

通信協(xié)議設(shè)計(jì)自由度方面:

在設(shè)計(jì)協(xié)議的時(shí)候,長(zhǎng)包會(huì)更加的自由,大多數(shù)情況都不需要考慮大數(shù)據(jù)傳輸?shù)?/span>占位問題,甚至在編碼上直接copy結(jié)構(gòu)體發(fā)送也是相當(dāng)方便的。

3

計(jì)算包數(shù)問題

既然長(zhǎng)包的設(shè)計(jì)相對(duì)比較方便。那分包處理是少不了的?

分包還不簡(jiǎn)單?

要發(fā)100個(gè)字節(jié)的數(shù)據(jù),每次只能發(fā)15個(gè),那發(fā)送7包就可以了,直接編碼,代碼如下:

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

這算是常規(guī)操作,如果覺得有點(diǎn)難度,還要多敲敲代碼。

一般用C語(yǔ)言比較久的朋友都想去簡(jiǎn)化這種操作,畢竟實(shí)現(xiàn)一個(gè)簡(jiǎn)單的功能需要兩行代碼,強(qiáng)迫癥,忍不了~

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


		

#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語(yǔ)言的幾個(gè)小技巧罷了,并沒有實(shí)質(zhì)性的改善。

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


		

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

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

該表達(dá)式主要是利用了取整的特性來(lái)達(dá)到+1的目的。

直接除單包個(gè)數(shù),不能整除的情況,結(jié)果都會(huì)少1,比如10/6,應(yīng)該是2包,而由于最終除法結(jié)果只能是1。

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

1、原本能夠整除的數(shù),補(bǔ)償后無(wú)法整除,結(jié)果與之前一致;

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

與我們分包個(gè)數(shù)是一致的,相當(dāng)巧妙。

4

擴(kuò)展

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

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

比如內(nèi)存的分區(qū),flash的設(shè)計(jì)上都是一個(gè)扇區(qū)一個(gè)扇區(qū)的分布。

現(xiàn)在想分配整數(shù)個(gè)扇形區(qū)域用于存儲(chǔ)某些數(shù)據(jù),每一個(gè)扇區(qū)512個(gè)字節(jié),存儲(chǔ)2000個(gè)字節(jié)的數(shù)據(jù),該分配幾個(gè)扇區(qū)?

我相信你已經(jīng)有答案了~

審核編輯 :李倩

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 數(shù)據(jù)
    +關(guān)注

    關(guān)注

    8

    文章

    7292

    瀏覽量

    93392
  • 數(shù)據(jù)包
    +關(guān)注

    關(guān)注

    0

    文章

    269

    瀏覽量

    25286
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4922

    瀏覽量

    72243

原文標(biāo)題:談?wù)剶?shù)據(jù)分包及相關(guān)小技巧

文章出處:【微信號(hào):gh_c472c2199c88,微信公眾號(hào):嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    使用fal api 來(lái)讀寫1024 字節(jié)數(shù)據(jù),需要需要考慮被高優(yōu)先級(jí)線程打斷嗎?

    使用fal api 來(lái)讀寫1024 字節(jié)數(shù)據(jù),需要需要考慮被高優(yōu)先級(jí)線程打斷嗎?
    發(fā)表于 10-10 07:16

    FlashDB 的TSDB不支持寫粒度為128,是出于什么考慮有這樣的限制?

    FlashDB 的TSDB不支持寫粒度為128,是出于什么考慮有這樣的限制? 如果我希望把這個(gè)數(shù)據(jù)庫(kù)移植到這樣的一個(gè)mcu上,我們應(yīng)該怎么做,有些建議嗎。 感謝各位大佬指點(diǎn)。
    發(fā)表于 09-23 08:19

    ADC和FPGA之間LVDS接口設(shè)計(jì)需要考慮的因素

    本文描述了ADC和FPGA之間LVDS接口設(shè)計(jì)需要考慮的因素,包括LVDS數(shù)據(jù)標(biāo)準(zhǔn)、LVDS接口數(shù)據(jù)時(shí)序違例解決方法以及硬件設(shè)計(jì)要點(diǎn)。
    的頭像 發(fā)表于 07-29 10:01 ?4597次閱讀
    ADC和FPGA之間LVDS接口設(shè)計(jì)需要<b class='flag-5'>考慮</b>的因素

    選擇錫絲直徑的關(guān)鍵考慮因素

    錫絲的直徑對(duì)于激光錫焊效果的影響非常大,如何選擇合適的錫絲直徑就顯得非常重要。松盛光電來(lái)給大家介紹選擇錫絲直徑的關(guān)鍵考慮因素,來(lái)了解一下吧。
    的頭像 發(fā)表于 04-24 10:54 ?495次閱讀

    設(shè)計(jì)早期對(duì)EMC的考慮

    這些經(jīng)驗(yàn)法則。結(jié)果,70%~90%的新設(shè)計(jì)都沒有通過第一次 EMC 測(cè)試,從而使后期重設(shè)計(jì)成本很高,如果制造商延誤產(chǎn)品發(fā)貨日期,損失的銷售費(fèi)用就更大。為了以低得多的成本確定并解決問題,設(shè)計(jì)師應(yīng)該考慮
    發(fā)表于 03-04 14:21

    村田電子考慮大規(guī)模并購(gòu)!

    全球最大電容生產(chǎn)商日本村田制作所社長(zhǎng)中島規(guī)巨表示,公司正在考慮進(jìn)行超過 1000 億日元 (約 6.65 億美元) 的并購(gòu),以推動(dòng)公司成長(zhǎng)。目標(biāo)是在截至 2027 財(cái)年的中期計(jì)劃期間內(nèi)完成。 村田
    的頭像 發(fā)表于 02-28 15:21 ?605次閱讀

    AN-825: iCoupler隔離產(chǎn)品的電源考慮因素

    電子發(fā)燒友網(wǎng)站提供《AN-825: iCoupler隔離產(chǎn)品的電源考慮因素.pdf》資料免費(fèi)下載
    發(fā)表于 01-15 16:33 ?0次下載
    AN-825: iCoupler隔離產(chǎn)品的電源<b class='flag-5'>考慮</b>因素

    AN-793: iCoupler隔離產(chǎn)品的ESD/閂鎖考慮因素

    電子發(fā)燒友網(wǎng)站提供《AN-793: iCoupler隔離產(chǎn)品的ESD/閂鎖考慮因素.pdf》資料免費(fèi)下載
    發(fā)表于 01-13 15:09 ?0次下載
    AN-793: iCoupler隔離產(chǎn)品的ESD/閂鎖<b class='flag-5'>考慮</b>因素

    選擇數(shù)字孿生廠商要考慮哪四點(diǎn)

    在選擇數(shù)字孿生廠商時(shí),企業(yè)需要考慮多方面因素以確保選擇到最適合自身需求的合作伙伴。以下是四個(gè)關(guān)鍵方面,企業(yè)在選擇數(shù)字孿生廠商時(shí)應(yīng)著重考慮: 一、廠商的行業(yè)經(jīng)驗(yàn)與技術(shù)能力 行業(yè)經(jīng)驗(yàn):廠商在相同或相鄰
    的頭像 發(fā)表于 12-18 11:39 ?362次閱讀

    選擇貼片電感型號(hào)時(shí)需要考慮什么參數(shù)?

    在選擇貼片電感型號(hào)時(shí),需要綜合考慮多個(gè)參數(shù)以確保電感能夠滿足電路的需求并保證其可靠性。以下是一些關(guān)鍵參數(shù)及其考慮因素: 1. 電感值(Inductance, L) 定義:電感值是電感的標(biāo)稱感值,反映
    的頭像 發(fā)表于 12-02 15:29 ?976次閱讀
    選擇貼片電感型號(hào)時(shí)需要<b class='flag-5'>考慮</b>什么參數(shù)?

    選擇數(shù)據(jù)采集器時(shí)需要考慮的因素

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

    請(qǐng)問AIC3254能不能替代C5502+AIC32B?

    問題:我把AIC32B采集到的數(shù)據(jù)通過C5502進(jìn)行分包處理,比如頻率倒序、數(shù)據(jù)加密,我有自己的算法,我想用AIC3254一顆芯片加MCU替代,不知道可行不可行啊?請(qǐng)專家給予回復(fù)??!在線等待!
    發(fā)表于 11-07 07:04

    socket編程的安全性考慮

    在Socket編程中,安全性是一個(gè)至關(guān)重要的考慮因素。以下是一些關(guān)鍵的安全性考慮和措施: 1. 數(shù)據(jù)加密 使用TLS/SSL協(xié)議 :TLS/SSL(傳輸層安全性/安全套接層)是網(wǎng)絡(luò)安全中最常用的協(xié)議
    的頭像 發(fā)表于 11-01 16:46 ?1014次閱讀

    BiCMOS ICs供電的考慮因素

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

    字節(jié)跳動(dòng)考慮在泰國(guó)新建數(shù)據(jù)中心

    據(jù)知情人士透露,字節(jié)跳動(dòng)旗下的BytePlus正在積極考慮于明年在泰國(guó)設(shè)立一個(gè)全新的數(shù)據(jù)中心。這一舉措旨在進(jìn)一步拓展公司在云計(jì)算和人工智能服務(wù)領(lǐng)域的全球布局。
    的頭像 發(fā)表于 10-22 17:05 ?908次閱讀