欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來(lái)到入門教程網(wǎng)!

C語(yǔ)言

當(dāng)前位置:主頁(yè) > 軟件編程 > C語(yǔ)言 >

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

來(lái)源:本站原創(chuàng)|時(shí)間:2020-01-10|欄目:C語(yǔ)言|點(diǎ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)鏈接

網(wǎng)頁(yè)制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語(yǔ)言數(shù)據(jù)庫(kù)服務(wù)器

如果侵犯了您的權(quán)利,請(qǐng)與我們聯(lián)系,我們將在24小時(shí)內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有