詳解C語言用malloc函數(shù)申請二維動態(tài)數(shù)組的實例
詳解C語言用malloc函數(shù)申請二維動態(tài)數(shù)組的實例
C語言在程序運行中動態(tài)的申請及釋放內(nèi)存十分方便,一維數(shù)組的申請及釋放比較簡單。
Sample one
#include <stdio.h>
int main()
{
char * p=(char *)malloc(sizeof(char)*5);//申請包含5個字符型的數(shù)組
free(p);
return 0;
}
是否申請二維動態(tài)內(nèi)存也如此簡單呢?答案是否定的。申請二維數(shù)組有一下幾種方法
Sample two
/* 申請一個5行3列的字符型數(shù)組*/ char **p=NULL;int i; p=(char ** )malloc(sizeof(char *)*5); for(i=0;i<5;i++) p[i]=malloc(sizeof(char)*3);
這種方式的優(yōu)點是行和列都是可變的,但釋放時必須釋放多次,先釋放p[n],在釋放p
/*釋放內(nèi)存*/ for(i=0;i<5;i++) free(p[i]); free(p);
Sample three
/*用指向數(shù)組的指針的方式申請內(nèi)存*/ char (*p)[3]=(char(*)[3])malloc(sizeof(char)*5*3)//p是一個指向包含3個元素的數(shù)組的指針
這種方式分配的內(nèi)存只須釋放一次
free(p);
這種方式的缺點是顯而易見的,列是不可變的!
如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
C++中關(guān)于std::queue?中遇到釋放內(nèi)存錯誤的問題
這篇文章主要介紹了std::queue中遇到釋放內(nèi)存錯誤的問題,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07
如何將編譯過的C++庫迅速部署在Visual?Studio新項目中
本文介紹在Visual?Studio中,通過屬性表,使得一個新建解決方案中的項目可以快速配置已有解決方案的項目中各類已編譯好的C++第三方庫的方法,感興趣的朋友跟隨小編一起看看吧2024-05-05
華為云開發(fā)工具CodeArts IDE for C/C++開發(fā)使用指南
CodeArts IDE是一個集成開發(fā)環(huán)境(IDE),它提供了開發(fā)語言和調(diào)試服務(wù),本文主要介紹了華為云開發(fā)工具CodeArts IDE for C/C++ 開發(fā)使用指南,感興趣的可以了解一下2023-08-08
使用C語言實現(xiàn)交換整數(shù)的奇數(shù)位和偶數(shù)位
在C語言中,要交換一個整數(shù)的二進(jìn)制位中的奇數(shù)位和偶數(shù)位,重點需要理解位操作,當(dāng)我們談?wù)摱M(jìn)制位的奇數(shù)位和偶數(shù)位時,我們是指從右到左數(shù)的位置,本文給大家介紹了使用C語言代碼實現(xiàn)將一個整數(shù)的奇數(shù)位和偶數(shù)位交換,需要的朋友可以參考下2025-03-03
如何調(diào)用C標(biāo)準(zhǔn)庫的exit函數(shù)詳解
這篇文章主要給大家介紹了關(guān)于如何調(diào)用C標(biāo)準(zhǔn)庫的exit函數(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07

