C語言數(shù)組int2str實現(xiàn)按協(xié)議存儲與按協(xié)議解析數(shù)據(jù)-創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(guān)C語言數(shù)組int2str實現(xiàn)按協(xié)議存儲與按協(xié)議解析數(shù)據(jù)的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

創(chuàng)新互聯(lián)主營阿爾山網(wǎng)站建設的網(wǎng)絡公司,主營網(wǎng)站建設方案,APP應用開發(fā),阿爾山h5成都小程序開發(fā)搭建,阿爾山網(wǎng)站營銷推廣歡迎阿爾山等地區(qū)企業(yè)咨詢

協(xié)議需求:

  • (1)序列號(1個字節(jié)) 屬性(1個字節(jié)) 名稱(18個字節(jié))

  • (2)現(xiàn)有一塊空間為600個字節(jié),以20個字節(jié)為單位,分別存儲以上數(shù)據(jù),直到存滿為止,并能解析。

根據(jù)協(xié)議,我們可以設計一個結(jié)構(gòu)體來表述這些數(shù)據(jù):

struct Data_Info
{
 char serial_num ;  //序列號 
 char property ;  //屬性 
 char sample_name[18]; //分類名稱 
};

恰恰在做嵌入式開發(fā)或者有關(guān)協(xié)議的開發(fā)就會要求類似這樣的需求,我們可以寫一個簡單的C程序模擬一下這個過程:

首先,模擬一堆已經(jīng)定義好的數(shù)據(jù),用來表示Data_Info里的分類名稱:

char *name[] = 
{
 "水果",
 "蔬菜",
 "啤酒",
 "酒精",
 "柴油",
 "娃哈哈",
 "奶茶",
 "雪碧",
 "可樂",
 "硫酸",
 "鹽酸",
 "硝酸" 
};

接下來,寫一個函數(shù),用于隨機初始化一塊600個字節(jié)的內(nèi)存空間,初始化600個字節(jié)中,以每20個字節(jié)為單位,分別按協(xié)議的要求初始化序列號、屬性、名稱。

//創(chuàng)建樣本庫數(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個字節(jié)里的數(shù)據(jù),按協(xié)議進行解析。

//輸出樣本庫信息 
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個字節(jié)為單位
  if(count == 20)
  { 
  //1.記錄起始地址
  end_position = offset_start ;
  //2.以20個字節(jié)作為分割點,分割數(shù)據(jù) 
  sample_data_info[count_number].serial_num = _data[end_position-20] ;  //20*n+0為庫的編號
  sample_data_info[count_number].property  = _data[end_position-19] ;  //20*n+1為庫的屬性
  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為庫的名稱 
  printf("編號:%d  屬性:%d  名稱:%s\n",sample_data_info[count_number].serial_num,sample_data_info[count_number].property,sample_data_info[count_number].sample_name);
  //記錄有多少個20
  count_number++ ;
  //將當前的計數(shù)清0 
  count = 0 ;  
  }
 }
}

主函數(shù)中,主要工作是開辟一塊600字節(jié)的內(nèi)存空間用于存儲,并調(diào)用以上的函數(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;
}

運行結(jié)果:

C語言數(shù)組int2str實現(xiàn)按協(xié)議存儲與按協(xié)議解析數(shù)據(jù)

在內(nèi)存足夠大的情況下,這無疑是非常好的方法,既簡單又粗暴,但在單片機的程序上,可能無法一次性分配如此大的,比如Ucos,一個棧的分配有限,現(xiàn)在,又如何來實現(xiàn)這樣的協(xié)議呢?不建議把棧改大,因為單片機沒有虛擬內(nèi)存管理機制,如果當前的任務改大了,其余的也就相對的要變小了。

感謝各位的閱讀!關(guān)于“C語言數(shù)組int2str實現(xiàn)按協(xié)議存儲與按協(xié)議解析數(shù)據(jù)”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)建站muchs.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

當前名稱:C語言數(shù)組int2str實現(xiàn)按協(xié)議存儲與按協(xié)議解析數(shù)據(jù)-創(chuàng)新互聯(lián)
分享網(wǎng)址:http://muchs.cn/article42/cdopec.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作定制網(wǎng)站、域名注冊、建站公司、網(wǎng)站營銷品牌網(wǎng)站設計

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化