您的位置:首页 > 编程语言 > C语言/C++

C语言中为指针的指针动态分配内存空间的做法

2017-04-02 15:14 274 查看
前言:本人在学习数据结构的过程中,遇到了散列这种数据结构,在使用分离链表发构建散列的过程中,需要用到为指针的指针动态分配内存空间,所以本人写了一个C语言的Demo程序来先测试这一行为

问题如图



#include "stdafx.h"
//输出数组测试
void PrinT(int *p,int size){
for (size_t i = 0; i < size; i++)
{
printf("%d ", p[i]);
}
printf("\n")
4000
;
}
int _tmain(int argc, _TCHAR* argv[])
{
int **p;
int GroupSize = 5;//外层size
int innerSize = 2;//内层size
//申请由外到内
p = (int**)malloc(sizeof(int*)*GroupSize);
for (size_t i = 0; i < GroupSize; i++)
{
//p[i]是一个innerSize大小的int数组的首地址
p[i] = (int*)malloc(sizeof(int)*innerSize);
for (size_t j = 0; j < innerSize; j++)
{
p[i][j] = i+j;
}
PrinT(p[i], innerSize);
}
//释放从内到外
for (size_t i = 0; i < innerSize; i++)
{
free(p[i]);
}
free(p);
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: