Java教程

利用动态内存来申请二维数组的方法

本文主要是介绍利用动态内存来申请二维数组的方法,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

 1、利用指针数组动态申请二维数组

int main()
{
	int** p = (int**)malloc(3 * sizeof(int*));//用二级指针先申请3个int *格子,即3行,因为是int**p,所以强转为(int**)
	for (int i = 0; i < 3; i++)//在上面申请的三个格子中再申请4个格子,即四列
	{
		p[i] = (int*)malloc(4 * sizeof(int));
	}
	//打印二维数组的地址
	for (int i = 0; i < 3; i++)
	{
		for (int j = 0; j < 4; j++)
		{
			printf("%p\n", &p[i][j]);
		}
	}
}

2、利用数组指针动态申请二维数组

int main()
{
	int(*p)[4] = (int(*)[4])malloc(3 * 4 * sizeof(int));//申请动态二维数组
	//打印地址
	for (int i = 0; i < 3; i++)
	{
		for (int j = 0; j < 4; j++)
		{
			printf("%p\n", &p[i][j]);
		}
	}
//打印结束后加入下一行代码进行内存释放
   free(p);//释放开辟的内存
	return 0;
}

3、用二维数组的思想去管理申请的一维数组

int main()
{
	int* p = (int*)malloc(3 * 4 * sizeof(int));//申请12个的一维数组 
	//用二维数组思想处理一维数组
	for (int i = 0; i < 3; i++)
	{
			for (int j = 0; j < 4; j++)
			{
				p[i * 4 + j] = 1;
				printf("%p\n", &p[i * 4 + j]);
			}
	}
    //下面结果是不释放内存的结果
	//free(p);//释放开辟的内存
	//return 0;
}

这篇关于利用动态内存来申请二维数组的方法的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!