C語(yǔ)言數(shù)組按協(xié)議存儲(chǔ)與按協(xié)議解析數(shù)據(jù)的實(shí)現(xiàn)
協(xié)議需求:
- (1)序列號(hào)(1個(gè)字節(jié)) 屬性(1個(gè)字節(jié)) 名稱(18個(gè)字節(jié))
- (2)現(xiàn)有一塊空間為600個(gè)字節(jié),以20個(gè)字節(jié)為單位,分別存儲(chǔ)以上數(shù)據(jù),直到存滿為止,并能解析。
根據(jù)協(xié)議,我們可以設(shè)計(jì)一個(gè)結(jié)構(gòu)體來(lái)表述這些數(shù)據(jù):
struct Data_Info { char serial_num ; //序列號(hào) char property ; //屬性 char sample_name[18]; //分類名稱 };
恰恰在做嵌入式開(kāi)發(fā)或者有關(guān)協(xié)議的開(kāi)發(fā)就會(huì)要求類似這樣的需求,我們可以寫(xiě)一個(gè)簡(jiǎn)單的C程序模擬一下這個(gè)過(guò)程:
首先,模擬一堆已經(jīng)定義好的數(shù)據(jù),用來(lái)表示Data_Info
里的分類名稱:
char *name[] = { "水果", "蔬菜", "啤酒", "酒精", "柴油", "娃哈哈", "奶茶", "雪碧", "可樂(lè)", "硫酸", "鹽酸", "硝酸" };
接下來(lái),寫(xiě)一個(gè)函數(shù),用于隨機(jī)初始化一塊600個(gè)字節(jié)的內(nèi)存空間,初始化600個(gè)字節(jié)中,以每20個(gè)字節(jié)為單位,分別按協(xié)議的要求初始化序列號(hào)、屬性、名稱。
//創(chuàng)建樣本庫(kù)數(shù)據(jù) void Create_Simple_Data(char *_data) { int i ; int count_num = 1 ; for(i = 0 ; i < 600 ; i++) { if(i % 20 == 0) { _data[i] = count_num ; _data[i+1] = rand()%2 ; memcpy(_data+i+2,name[rand()%7],18); count_num++ ; } } }
輸出數(shù)據(jù)的函數(shù),用于輸出600個(gè)字節(jié)里的數(shù)據(jù),按協(xié)議進(jìn)行解析。
//輸出樣本庫(kù)信息 void Put_Simple_Data(char *_data) { int offset_start = 0 , count = 0 , end_position = 0 ; int end_position_save = 0 ; int count_number = 0 ; count_number = 0 ; for(offset_start = 0 , count = 0 ; \ offset_start < 600 ; \ offset_start++ ,count++) \ { //每20個(gè)字節(jié)為單位 if(count == 20) { //1.記錄起始地址 end_position = offset_start ; //2.以20個(gè)字節(jié)作為分割點(diǎn),分割數(shù)據(jù) sample_data_info[count_number].serial_num = _data[end_position-20] ; //20*n+0為庫(kù)的編號(hào) sample_data_info[count_number].property = _data[end_position-19] ; //20*n+1為庫(kù)的屬性 memset(sample_data_info[count_number].sample_name,0,18); memcpy(sample_data_info[count_number].sample_name,(_data+2)+(20*count_number),18); //20*n+2....20*n+2+18為庫(kù)的名稱 printf("編號(hào):%d 屬性:%d 名稱:%s\n",sample_data_info[count_number].serial_num,sample_data_info[count_number].property,sample_data_info[count_number].sample_name); //記錄有多少個(gè)20 count_number++ ; //將當(dāng)前的計(jì)數(shù)清0 count = 0 ; } } }
主函數(shù)中,主要工作是開(kāi)辟一塊600字節(jié)的內(nèi)存空間用于存儲(chǔ),并調(diào)用以上的函數(shù)實(shí)現(xiàn)功能:
int main (void) { char *_data = NULL ; _data = malloc(600); Create_Simple_Data(_data); Put_Simple_Data(_data); free(_data); _data = NULL ; return 0; }
運(yùn)行結(jié)果:
在內(nèi)存足夠大的情況下,這無(wú)疑是非常好的方法,既簡(jiǎn)單又粗暴,但在單片機(jī)的程序上,可能無(wú)法一次性分配如此大的,比如Ucos,一個(gè)棧的分配有限,現(xiàn)在,又如何來(lái)實(shí)現(xiàn)這樣的協(xié)議呢?不建議把棧改大,因?yàn)閱纹瑱C(jī)沒(méi)有虛擬內(nèi)存管理機(jī)制,如果當(dāng)前的任務(wù)改大了,其余的也就相對(duì)的要變小了。開(kāi)動(dòng)腦筋吧!
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
C語(yǔ)言實(shí)現(xiàn)單鏈表的基本操作分享
單鏈表是一種鏈?zhǔn)酱嫒〉臄?shù)據(jù)結(jié)構(gòu),用一組地址任意的存儲(chǔ)單元存放線性表中的數(shù)據(jù)元素。本文將為大家介紹C語(yǔ)言中單鏈表的基本操作,需要的可以參考一下2022-10-10C++實(shí)現(xiàn)LeetCode(114.將二叉樹(shù)展開(kāi)成鏈表)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(114.將二叉樹(shù)展開(kāi)成鏈表),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07詳解C/C++高精度算法的簡(jiǎn)單實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了C/C++中高精度算法(加減乘除)的簡(jiǎn)單實(shí)現(xiàn),方便以后需要時(shí)拷貝使用。感興趣的小伙伴可以跟隨小編一起了解一下2022-12-12C語(yǔ)言中儲(chǔ)存類別與內(nèi)存管理的深入理解
這篇文章主要給大家介紹了關(guān)于C語(yǔ)言中儲(chǔ)存類別與內(nèi)存管理的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03C++靜態(tài)庫(kù)與動(dòng)態(tài)庫(kù)文件的生成和使用教程
庫(kù)文件是計(jì)算機(jī)上的一類文件,可以簡(jiǎn)單的把庫(kù)文件看成一種代碼倉(cāng)庫(kù),它提供給使用者一些可以直接拿來(lái)用的變量、函數(shù)和類,下面這篇文章主要給大家介紹了關(guān)于C++靜態(tài)庫(kù)與動(dòng)態(tài)庫(kù)文件的生成和使用的相關(guān)資料,需要的朋友可以參考下2023-03-03在C++中把字符串轉(zhuǎn)換為整數(shù)的兩種簡(jiǎn)單方法
經(jīng)常會(huì)遇到類型轉(zhuǎn)換,本文主要介紹了C++中把字符串轉(zhuǎn)換為整數(shù)的兩種簡(jiǎn)單方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06C語(yǔ)言中單鏈表的基本操作(創(chuàng)建、銷毀、增刪查改等)
這篇文章主要介紹了C語(yǔ)言中單鏈表的基本操作(創(chuàng)建、銷毀、增刪查改等),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02關(guān)于C++復(fù)制構(gòu)造函數(shù)的實(shí)現(xiàn)講解
今天小編就為大家分享一篇關(guān)于關(guān)于C++復(fù)制構(gòu)造函數(shù)的實(shí)現(xiàn)講解,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2018-12-12