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

C語言?柔性數組的使用詳解

 更新時間:2022年03月30日 10:04:31   作者:二球懸鈴木丶  
柔性數組(Flexible?Array)是引入的一個新特性,它允許你在定義結構體時創(chuàng)建一個空數組,而這個數組的大小可以在程序運行的過程中根據你的需求進行更改特別注意的一點是:這個空數組必須聲明為結構體的最后一個成員,并且還要求這樣的結構體至少包含一個其他類型的成員

一.柔性數組的特點

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

這段代碼的輸出是什么?

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

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

原來,這是一種柔性數組。

1.結構體中最后一個元素允許是未知大小的數組,這個數組就是柔性數組。

2.結構中的柔性數組前面必須有至少一個其他成員。

3.sizeof返回的這種結構大小不包括柔性數組的內存。

4.包含柔數組成員的結構用malloc函數進行內存的動態(tài)分配,且分配的內存應該大于結構的大小,以適應柔性數組的預期大小。

二.柔性數組的使用

1.如何使用柔性數組

包含柔數組成員的結構用malloc函數進行內存的動態(tài)分配,

且分配的內存應該大于結構的大小,以適應柔性數組的預期大小。

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
 
struct S
{
	int x;
	int a[];
};
int main()
{
    //為柔性數組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;                                   //數組使用
	}
	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;
}

2.不用柔性數組的話有什么代替

我們經常用字符串指針來申請空間,

那我們直接給字符串指針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個字節(jié)的空間
	if (ps->a == NULL)
	{
		free(ps);
		ps = NULL;
		return 1;
	}
	free(ps->a);
	ps->a = NULL;
 
	free(ps);
	ps = NULL;
}

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

但是柔性數組相對而言更好。

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

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

1.方便內存釋放

  • 使用柔性數組我們只用free一次,
  • 而使用字符串指針要free兩次,有內存泄漏的風險

2.提高訪問速度

  • 柔性數組malloc了一次,是連續(xù)的內存,
  • 有益于提高訪問速度,減少內存碎片。

到此這篇關于C語言 柔性數組的使用詳解的文章就介紹到這了,更多相關C語言 柔性數組內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • C語言rewind與fseek函數之隨機讀寫文件的用法詳解

    C語言rewind與fseek函數之隨機讀寫文件的用法詳解

    這篇文章主要介紹了C語言rewind與fseek函數之隨機讀寫文件的用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下
    2021-09-09
  • C語言求2的n次方多種方法總結

    C語言求2的n次方多種方法總結

    這篇文章主要給大家介紹了關于C語言求2的n次方多種方法的相關資料,求2的N次冪是一個常用的功能,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-10-10
  • C++中fstream,ifstream及ofstream用法淺析

    C++中fstream,ifstream及ofstream用法淺析

    這篇文章主要介紹了C++中fstream,ifstream及ofstream用法,適合C++初學者學習文件流的操作,需要的朋友可以參考下
    2014-08-08
  • C/C++實現通訊錄管理系統(tǒng)(附源碼)

    C/C++實現通訊錄管理系統(tǒng)(附源碼)

    這篇文章主要為大家詳細介紹了如何利用C++實現通訊錄管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-12-12
  • APUE筆記之:進程環(huán)境詳解

    APUE筆記之:進程環(huán)境詳解

    本篇文章是對APUE 進程環(huán)境詳解進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • Qt使用流處理XML文件的示例代碼

    Qt使用流處理XML文件的示例代碼

    XML(eXtensible?Markup?Language)是一種通用的文本格式,被廣泛運用于數據交換和數據存儲。本文主要來和大家聊聊如何使用?Qt?處理?XML?格式的文檔,需要的可以參考一下
    2023-02-02
  • C語言編程之動態(tài)內存與柔性數組的了解

    C語言編程之動態(tài)內存與柔性數組的了解

    本文是C語言編程篇,這篇文章主要為大家介紹了C語言編程中動態(tài)內存的函數與柔性數組的特點,有需要的朋友可以借鑒參考下,希望可以有所幫助
    2021-09-09
  • 關于C++中0是十進制還是八進制的問題

    關于C++中0是十進制還是八進制的問題

    本篇文章中,小編將為大家介紹關于C++中0是十進制還是八進制的問題,有需要的朋友可以參考一下
    2013-04-04
  • C語言使用setjmp和longjmp實現一個簡單的協(xié)程

    C語言使用setjmp和longjmp實現一個簡單的協(xié)程

    這篇文章主要為大家介紹了C語言使用setjmp和longjmp實現一個簡單的協(xié)程過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • C語言實現打印楊輝三角的方法詳細(三種方法)

    C語言實現打印楊輝三角的方法詳細(三種方法)

    楊輝三角是中國古代數學的杰出研究成果之一,它把二項式系數圖形化,把組合數內在的一些代數性質直觀地從圖形中體現出來,是一種離散型的數與形的結合。本文將介紹三種可以實現打印楊輝三角的辦法,感興趣的可以試一試
    2022-01-01

最新評論