柔性數(shù)組在實(shí)際項(xiàng)目中的應(yīng)用?
掃描二維碼
隨時(shí)隨地手機(jī)看文章
柔性數(shù)組在實(shí)際中應(yīng)用還是挺多的,看過上一篇文章分享一種靈活性很高的協(xié)議格式(附代碼例子)的小伙伴不知有沒有注意到我們有使用了柔性數(shù)組:
本篇文章我們就來一起學(xué)習(xí)柔性數(shù)組。
什么是柔性數(shù)組?
C99中,結(jié)構(gòu)體中的最后一個(gè)元素允許是未知大小的數(shù)組,這就叫作 柔性數(shù)組 。
柔性數(shù)組的特點(diǎn):
- 結(jié)構(gòu)體中柔性數(shù)組成員前面必須至少有一個(gè)其他成員。
- sizeof返回的這種結(jié)構(gòu)大小不包括柔性數(shù)組的內(nèi)存。
- 包含柔性數(shù)組成員的結(jié)構(gòu)用malloc()函數(shù)進(jìn)行內(nèi)存的動(dòng)態(tài)分配。
例子:
// 微信公眾號(hào):嵌入式大雜燴 #include #include #include typedef struct _data { int len; char val[];
}data_t; int main(int arc, char *argv[]) { data_t test_data1 = {0}; printf("sizeof(data_t) = %ld\n", sizeof(data_t)); char *src_data = "hello flexible arr"; // 為結(jié)構(gòu)體及其柔性數(shù)組成員申請(qǐng)一塊連續(xù)的空間 int len = strlen(src_data) + 1; data_t *p_test_data2 =(data_t*)malloc(sizeof(data_t) + sizeof(char) * len); if (NULL == p_test_data2)
{ printf("malloc p_test_data2 error\n"); return EXIT_FAILURE;
} // 填充結(jié)構(gòu)體 p_test_data2->len = len; strncpy(p_test_data2->val, src_data, p_test_data2->len); printf("p_test_data2->val = %s\n", p_test_data2->val); // 釋放內(nèi)存 free(p_test_data2);
p_test_data2 = NULL; return 0;
}
編譯、運(yùn)行:
下面我們一起通過實(shí)例來認(rèn)識(shí)柔性數(shù)組的優(yōu)點(diǎn)。
柔性數(shù)組與指針的區(qū)別?
上一節(jié)的協(xié)議格式結(jié)構(gòu)體其實(shí)可以又如下兩種創(chuàng)建方式:
-
value字段以柔性數(shù)組的方式定義:
typedef struct _protocol_format { uint16_t head; uint8_t id; uint8_t type; uint8_t length; uint8_t value[];
}protocol_format_t;
-
value字段以指針的方式定義:
typedef struct _protocol_format { uint16_t head; uint8_t id; uint8_t type; uint8_t length; uint8_t *value;
}protocol_format_t;
(1)結(jié)構(gòu)體占用空間
柔性數(shù)組的方式結(jié)構(gòu)體占用較指針的方式少。
柔性數(shù)組方式:
指針方式:
(2)代碼簡(jiǎn)潔及訪問速度方面
柔性數(shù)組的方式相對(duì)與指針的方式更為簡(jiǎn)潔,柔性數(shù)組的方式只需要申請(qǐng)一次空間,給結(jié)構(gòu)體申請(qǐng)空間的同時(shí)也給柔性數(shù)組申請(qǐng)空間;而指針的方式,除了給結(jié)構(gòu)體申請(qǐng)空間之外,還得給結(jié)構(gòu)體里的指針成員申請(qǐng)空間。
柔性數(shù)組方式:
指針方式:
使用指針的方式寫代碼會(huì)比柔性數(shù)組的方式會(huì)繁瑣一些,特別地,如果在釋放內(nèi)存的時(shí)候把順序弄反了,則結(jié)構(gòu)體里的指針成員所指向的內(nèi)存就釋放不掉,會(huì)造成內(nèi)存泄露。
柔性數(shù)組的方式只需要申請(qǐng)一次空間,是一塊連續(xù)的空間;而指針的方式,申請(qǐng)的兩塊空間不是連續(xù)的。連續(xù)的內(nèi)存有益于提高訪問速度。
當(dāng)然,前面介紹柔性數(shù)組的時(shí)候有說到,柔性數(shù)組是在C99標(biāo)準(zhǔn)及之后才有的,如果你的編譯器還是比較古老的,那還是選用指針的方式,通用性也會(huì)比較好。
以上就是本次的分享,期待你的點(diǎn)贊、收藏、轉(zhuǎn)發(fā)!
注意
由于微信公眾號(hào)近期改變了推送規(guī)則,為了防止找不到,可以星標(biāo)置頂,這樣每次推送的文章才會(huì)出現(xiàn)在您的訂閱列表里。
猜你喜歡:
分享一種靈活性很高的協(xié)議格式(附代碼例子)
嵌入式大雜燴周記 | 第 15 期
訪問非法內(nèi)存為什么不會(huì)出錯(cuò)?
嵌入式大雜燴周記 | 第 14 期
分享幾個(gè)實(shí)用的代碼片段(第二彈)
分享一種你可能不知道的bug定位方法
分享一種修改配置文件的方法
《嵌入式大雜燴周記第 13 期:lz4》
《嵌入式并行多線程處理器,了解一下!》
《分享一種修改配置文件的方法》
《分享幾個(gè)實(shí)用的代碼片段(附代碼例子)》
《廢舊板子再利用:搭建無線調(diào)試環(huán)境!》
《嵌入式段錯(cuò)誤的3種調(diào)試方法匯總!》
《簡(jiǎn)說TCP通信非阻塞接收(附代碼例子)》
《TCP通信常用接口的使用封裝》
《寫國(guó)際化的嵌入式代碼,時(shí)間問題如何處理?》
《Linux命令行萬能解壓命令》
《嵌入式軟件中,總線錯(cuò)誤的坑?替大家先踩一步》
《分享嵌入式軟件調(diào)試方法及幾個(gè)有用的工具!》
《分享兩點(diǎn)提高編程能力的建議!》
在公眾號(hào)聊天界面回復(fù)1024,可獲取嵌入式資源;回復(fù) m ,可查看文章匯總