您好,登錄后才能下訂單哦!
這篇文章主要介紹了C語言如何使用柔性數組,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
struct S { int x; int a[]; }; int main() { printf("%d", sizeof(S)); }
這段代碼的輸出是什么?
我們打印結構體S所占空間的大小,這個a[]占多少字節呢?
輸出結果是4,可一個int類型的x就是4了,a[]去哪了?好奇怪哦。
原來,這是一種柔性數組。
1.結構體中最后一個元素允許是未知大小的數組,這個數組就是柔性數組。
2.結構中的柔性數組前面必須有至少一個其他成員。
3.sizeof返回的這種結構大小不包括柔性數組的內存。
4.包含柔數組成員的結構用malloc函數進行內存的動態分配,且分配的內存應該大于結構的大小,以適應柔性數組的預期大小。
包含柔數組成員的結構用malloc函數進行內存的動態分配,
且分配的內存應該大于結構的大小,以適應柔性數組的預期大小。
#define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h> #include<stdlib.h> struct S { int x; int a[]; }; int main() { //為柔性數組a[]開辟了40個字節的空間 struct S *ps =(struct S*)malloc(sizeof(struct S) + 40); if (ps == NULL) //檢查是否為空指針 { perror("ps"); return 1; } ps->x = 10; int i = 0; for (i = 0; i < 10; i++) { ps->a[i] = i; //數組使用 } for (i = 0; i < 10; i++) { printf("%d ",ps->a[i]); //數組打印 } //若覺得40不夠用,可用realloc擴容 //如: struct S* ptr = (struct S*)realloc(ps, sizeof(struct S) + 80); if (ptr == NULL) //檢查是否為空指針 { perror("realloc"); return 1; } else { ps = ptr; } free(ps); //釋放內存并置為空指針 ps = NULL; }
我們經常用字符串指針來申請空間,
那我們直接給字符串指針malloc一塊空間,不就行了嗎,
為什么還要用柔性數組呢?
#define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h> #include<stdlib.h> struct S { int x; int *a; }; int main() { struct S* ps = (struct S*)malloc(sizeof(struct S) );//為結構體變量x開辟空間 if (ps == NULL) { return 1; } ps->a = (int*)malloc(40); //為字符串指針開辟40個字節的空間 if (ps->a == NULL) { free(ps); ps = NULL; return 1; } free(ps->a); ps->a = NULL; free(ps); ps = NULL; }
上述代碼確實可以完成相同的功能,
但是柔性數組相對而言更好。
讓我們來看看柔性數組的優勢。
使用柔性數組我們只用free一次,
而使用字符串指針要free兩次,有內存泄漏的風險
柔性數組malloc了一次,是連續的內存,
有益于提高訪問速度,減少內存碎片。
感謝你能夠認真閱讀完這篇文章,希望小編分享的“C語言如何使用柔性數組”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。