協(xié)議需求:
根據(jù)協(xié)議,我們可以設(shè)計(jì)一個(gè)結(jié)構(gòu)體來表述這些數(shù)據(jù):
struct Data_Info{ char serial_num ;  //序列號  char property ;  //屬性  char sample_name[18]; //分類名稱 };恰恰在做嵌入式開發(fā)或者有關(guān)協(xié)議的開發(fā)就會要求類似這樣的需求,我們可以寫一個(gè)簡單的C程序模擬一下這個(gè)過程:
首先,模擬一堆已經(jīng)定義好的數(shù)據(jù),用來表示Data_Info里的分類名稱:
char *name[] = { "水果", "蔬菜", "啤酒", "酒精", "柴油", "娃哈哈", "奶茶", "雪碧", "可樂", "硫酸", "鹽酸", "硝酸" };接下來,寫一個(gè)函數(shù),用于隨機(jī)初始化一塊600個(gè)字節(jié)的內(nèi)存空間,初始化600個(gè)字節(jié)中,以每20個(gè)字節(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個(gè)字節(jié)里的數(shù)據(jù),按協(xié)議進(jìn)行解析。
//輸出樣本庫信息 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為庫的編號  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);  //記錄有多少個(gè)20  count_number++ ;  //將當(dāng)前的計(jì)數(shù)清0   count = 0 ;    } }}主函數(shù)中,主要工作是開辟一塊600字節(jié)的內(nèi)存空間用于存儲,并調(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)存足夠大的情況下,這無疑是非常好的方法,既簡單又粗暴,但在單片機(jī)的程序上,可能無法一次性分配如此大的,比如Ucos,一個(gè)棧的分配有限,現(xiàn)在,又如何來實(shí)現(xiàn)這樣的協(xié)議呢?不建議把棧改大,因?yàn)閱纹瑱C(jī)沒有虛擬內(nèi)存管理機(jī)制,如果當(dāng)前的任務(wù)改大了,其余的也就相對的要變小了。開動腦筋吧!
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對武林網(wǎng)的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
新聞熱點(diǎn)
疑難解答
圖片精選