c語(yǔ)言動(dòng)態(tài)內(nèi)存分配知識(shí)點(diǎn)及實(shí)例
c語(yǔ)言怎么實(shí)現(xiàn)動(dòng)態(tài)內(nèi)存分配
我們經(jīng)常會(huì)預(yù)先給程序開辟好內(nèi)存空間,然后進(jìn)行操作。
int arr[5] ;
對(duì)這個(gè)數(shù)組我們?cè)诙x的時(shí)候必須給提前開辟好空間,并且在程序執(zhí)行的過程中,這個(gè)開辟的內(nèi)存空間是一直存在的,除非等到這個(gè)函數(shù)執(zhí)行完畢,才會(huì)將空間釋放。有個(gè)問題就是這個(gè)數(shù)組在程序中無法被修改。
這些問題給我們?cè)斐闪艘恍┦褂蒙系牟环奖?,所以,C中提供了malloc()函數(shù)。
關(guān)于malloc()函數(shù),這個(gè)函數(shù)它接受一個(gè)參數(shù):就是所需的內(nèi)存的字節(jié)數(shù)。然后malloc()找到可用內(nèi)存中那一個(gè)大小適合的塊。在這個(gè)過程中,malloc()可以來返回那塊內(nèi)存第一個(gè)字節(jié)的地址。所以,也就意味了我們可以使用指針來操作。malloc()可以用來返回?cái)?shù)組指針、結(jié)構(gòu)指針等等,所以我們需要把返回值的類型指派為適當(dāng)?shù)念愋?。?dāng)malloc()找不到所需的空間時(shí),它將返回空指針。
例:
double *p; p=(double*)malloc(30*sizeof(double));
在這個(gè)程序中,首先開辟了30個(gè)double類型的空間,然后把p指向這個(gè)空間的位置。在這里的指針是指向第一個(gè)double值。并不是我們?nèi)块_辟的30個(gè)double的空間。這就和數(shù)組一樣,指向數(shù)組的指針式指向數(shù)組首元素的地址,并不是整個(gè)數(shù)組的元素。所以,在這里我們的操作也和數(shù)組是一樣的,
p[0]就是第一個(gè)元素,p[1]就是第二個(gè)元素。
至此,我們就可以掌握到一種聲明動(dòng)態(tài)數(shù)組的方法。
int arr[n]; p=(int *)malloc(n*sizeof(int)); //我們?cè)谶@里使用的時(shí)候要元素個(gè)數(shù)乘類型字節(jié)長(zhǎng)度,這樣就達(dá)到了動(dòng)態(tài)開辟內(nèi)存空間。
當(dāng)我們使用malloc()開辟完內(nèi)存空間以后,我們所要考慮的就是釋放內(nèi)存空間,在這里,C給我們提供了free()函數(shù)。free()的參數(shù)就是malloc()函數(shù)所返回的地址,釋放先前malloc()函數(shù)所開辟的空間。
例:
對(duì)于上面我們所開辟的空間進(jìn)行釋放,那么我們就可以這樣
free(p);
程序還調(diào)用了exit()函數(shù),這個(gè)函數(shù)是在內(nèi)存分配失敗時(shí)結(jié)束程序。
程序例子:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<malloc.h>//malloc()函數(shù)被包含在malloc.h里面
#include<stdlib.h>
int main(void)
{
char*a = NULL;//聲明一個(gè)指向a的char*類型的指針
a = (char*)malloc(100 * sizeof(char));//使用malloc分配內(nèi)存的首地址,然后賦值給a
if (!a)//如果malloc失敗,可以得到一些log
{
perror("malloc");
return-1;
}
sprintf(a, "%s", "HelloWorld\n");//"HelloWorld\n"寫入a指向的地址
printf("%s\n", a);//輸出用戶輸入的數(shù)據(jù)
free(a);//釋放掉使用的內(nèi)存地址
system("pause");
return 0;//例2有無內(nèi)存泄露?
}
這個(gè)程序主要用來檢測(cè)malloc返回值條件有誤。
在這里我們需要注意,在C中,類型指派(char *)是可選的,但是在C++中這個(gè)是必須有的,所以使用類型指派將使把C程序移植到C++更容易。
使用動(dòng)態(tài)數(shù)組,主要是為了獲得程序的靈活性。我們可以需要多少個(gè)元素就讓數(shù)組開辟多少個(gè)。不需要浪費(fèi)空間。
知識(shí)點(diǎn)補(bǔ)充:
常見的動(dòng)態(tài)內(nèi)存錯(cuò)誤
常見的錯(cuò)誤有:對(duì)NULL指針進(jìn)行解引用操作、對(duì)分配的內(nèi)存進(jìn)行操作時(shí)越過邊界、釋放并非內(nèi)存分配的內(nèi)存、試圖釋放一塊動(dòng)態(tài)分配的內(nèi)存的一部分以及一塊動(dòng)態(tài)內(nèi)存釋放之后被繼續(xù)使用。
到此這篇關(guān)于c語(yǔ)言動(dòng)態(tài)內(nèi)存分配知識(shí)點(diǎn)及實(shí)例的文章就介紹到這了,更多相關(guān)c語(yǔ)言怎么實(shí)現(xiàn)動(dòng)態(tài)內(nèi)存分配內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++實(shí)踐排序函數(shù)模板項(xiàng)目的參考方法
今天小編就為大家分享一篇關(guān)于C++實(shí)踐排序函數(shù)模板項(xiàng)目的參考方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-02-02
C++中的多態(tài)問題—理解虛函數(shù)表及多態(tài)實(shí)現(xiàn)原理
這篇文章主要介紹了C++中的多態(tài)問題—理解虛函數(shù)表及多態(tài)實(shí)現(xiàn)原理,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
C語(yǔ)言實(shí)現(xiàn)數(shù)獨(dú)輔助器(附源碼)
數(shù)獨(dú)是源自瑞士的一種數(shù)學(xué)游戲。是一種運(yùn)用紙、筆進(jìn)行演算的邏輯游戲。本文將利用C語(yǔ)言制作一個(gè)數(shù)獨(dú)輔助器,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-01-01
C語(yǔ)言文件操作函數(shù)freopen詳細(xì)解析
替換一個(gè)流,或者說重新分配文件指針,實(shí)現(xiàn)重定向。如果stream流已經(jīng)打開,則先關(guān)閉該流。如果該流已經(jīng)定向,則freopen將會(huì)清除該定向。此函數(shù)一般用于將一個(gè)指定的文件打開一個(gè)預(yù)定義的流:標(biāo)準(zhǔn)輸入、標(biāo)準(zhǔn)輸出或者標(biāo)準(zhǔn)出錯(cuò)2013-10-10
C語(yǔ)言運(yùn)用函數(shù)指針數(shù)組實(shí)現(xiàn)計(jì)算器功能
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言運(yùn)用函數(shù)指針數(shù)組實(shí)現(xiàn)計(jì)算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10

