欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2018年12月14日 14:48:35   作者:Engineer-Bruce_Yang  
今天小編就為大家分享一篇關于C語言數(shù)組按協(xié)議存儲與按協(xié)議解析數(shù)據(jù)的實現(xiàn),小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

協(xié)議需求:

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

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

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

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

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

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

接下來,寫一個函數(shù),用于隨機初始化一塊600個字節(jié)的內存空間,初始化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é)的內存空間用于存儲,并調用以上的函數(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;
}

運行結果:

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

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接

相關文章

  • C語言每日練習之冒泡排序

    C語言每日練習之冒泡排序

    這篇文章主要介紹了C語言冒泡排序,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-11-11
  • C語言實現(xiàn)單鏈表的基本操作分享

    C語言實現(xiàn)單鏈表的基本操作分享

    單鏈表是一種鏈式存取的數(shù)據(jù)結構,用一組地址任意的存儲單元存放線性表中的數(shù)據(jù)元素。本文將為大家介紹C語言中單鏈表的基本操作,需要的可以參考一下
    2022-10-10
  • C++實現(xiàn)LeetCode(114.將二叉樹展開成鏈表)

    C++實現(xiàn)LeetCode(114.將二叉樹展開成鏈表)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(114.將二叉樹展開成鏈表),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下
    2021-07-07
  • 詳解C/C++高精度算法的簡單實現(xiàn)

    詳解C/C++高精度算法的簡單實現(xiàn)

    這篇文章主要為大家詳細介紹了C/C++中高精度算法(加減乘除)的簡單實現(xiàn),方便以后需要時拷貝使用。感興趣的小伙伴可以跟隨小編一起了解一下
    2022-12-12
  • C語言中儲存類別與內存管理的深入理解

    C語言中儲存類別與內存管理的深入理解

    這篇文章主要給大家介紹了關于C語言中儲存類別與內存管理的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • C++靜態(tài)庫與動態(tài)庫文件的生成和使用教程

    C++靜態(tài)庫與動態(tài)庫文件的生成和使用教程

    庫文件是計算機上的一類文件,可以簡單的把庫文件看成一種代碼倉庫,它提供給使用者一些可以直接拿來用的變量、函數(shù)和類,下面這篇文章主要給大家介紹了關于C++靜態(tài)庫與動態(tài)庫文件的生成和使用的相關資料,需要的朋友可以參考下
    2023-03-03
  • C語言掃雷游戲的實現(xiàn)方法

    C語言掃雷游戲的實現(xiàn)方法

    這篇文章主要為大家詳細介紹了C語言掃雷游戲的實現(xiàn)方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • 在C++中把字符串轉換為整數(shù)的兩種簡單方法

    在C++中把字符串轉換為整數(shù)的兩種簡單方法

    經常會遇到類型轉換,本文主要介紹了C++中把字符串轉換為整數(shù)的兩種簡單方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-06-06
  • C語言中單鏈表的基本操作(創(chuàng)建、銷毀、增刪查改等)

    C語言中單鏈表的基本操作(創(chuàng)建、銷毀、增刪查改等)

    這篇文章主要介紹了C語言中單鏈表的基本操作(創(chuàng)建、銷毀、增刪查改等),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • 關于C++復制構造函數(shù)的實現(xiàn)講解

    關于C++復制構造函數(shù)的實現(xiàn)講解

    今天小編就為大家分享一篇關于關于C++復制構造函數(shù)的實現(xiàn)講解,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-12-12

最新評論