溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

C語言如何使用柔性數(shù)組

發(fā)布時間:2022-03-30 12:25:23 來源:億速云 閱讀:185 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹了C語言如何使用柔性數(shù)組,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

一.柔性數(shù)組的特點

struct S
{
	int x;
	int a[];
};
int main()
{
	printf("%d", sizeof(S));
}

這段代碼的輸出是什么?

我們打印結(jié)構(gòu)體S所占空間的大小,這個a[]占多少字節(jié)呢?

輸出結(jié)果是4,可一個int類型的x就是4了,a[]去哪了?好奇怪哦。

原來,這是一種柔性數(shù)組。

1.結(jié)構(gòu)體中最后一個元素允許是未知大小的數(shù)組,這個數(shù)組就是柔性數(shù)組。

2.結(jié)構(gòu)中的柔性數(shù)組前面必須有至少一個其他成員。

3.sizeof返回的這種結(jié)構(gòu)大小不包括柔性數(shù)組的內(nèi)存。

4.包含柔數(shù)組成員的結(jié)構(gòu)用malloc函數(shù)進行內(nèi)存的動態(tài)分配,且分配的內(nèi)存應(yīng)該大于結(jié)構(gòu)的大小,以適應(yīng)柔性數(shù)組的預(yù)期大小。

二.柔性數(shù)組的使用

1.如何使用柔性數(shù)組

包含柔數(shù)組成員的結(jié)構(gòu)用malloc函數(shù)進行內(nèi)存的動態(tài)分配,

且分配的內(nèi)存應(yīng)該大于結(jié)構(gòu)的大小,以適應(yīng)柔性數(shù)組的預(yù)期大小。

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
 
struct S
{
	int x;
	int a[];
};
int main()
{
    //為柔性數(shù)組a[]開辟了40個字節(jié)的空間
	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;                                   //數(shù)組使用
	}
	for (i = 0; i < 10; i++)
	{
		printf("%d  ",ps->a[i]);                        //數(shù)組打印
	}
	//若覺得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);                                            //釋放內(nèi)存并置為空指針
	ps = NULL;
}

2.不用柔性數(shù)組的話有什么代替

我們經(jīng)常用字符串指針來申請空間,

那我們直接給字符串指針malloc一塊空間,不就行了嗎,

為什么還要用柔性數(shù)組呢?

#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) );//為結(jié)構(gòu)體變量x開辟空間
	if (ps == NULL)
	{
		return 1;
	}
	ps->a = (int*)malloc(40);							//為字符串指針開辟40個字節(jié)的空間
	if (ps->a == NULL)
	{
		free(ps);
		ps = NULL;
		return 1;
	}
	free(ps->a);
	ps->a = NULL;
 
	free(ps);
	ps = NULL;
}

上述代碼確實可以完成相同的功能,

但是柔性數(shù)組相對而言更好。

讓我們來看看柔性數(shù)組的優(yōu)勢。

三.柔性數(shù)組的優(yōu)勢

1.方便內(nèi)存釋放

  • 使用柔性數(shù)組我們只用free一次,

  • 而使用字符串指針要free兩次,有內(nèi)存泄漏的風(fēng)險

2.提高訪問速度

  • 柔性數(shù)組malloc了一次,是連續(xù)的內(nèi)存,

  • 有益于提高訪問速度,減少內(nèi)存碎片。

感謝你能夠認真閱讀完這篇文章,希望小編分享的“C語言如何使用柔性數(shù)組”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI