牛骨文教育服务平台(让学习变的简单)
博文笔记

new一个动态二维数组并实现内存连续

创建时间:2016-03-13 投稿人: 浏览次数:468

#include <iostream>
using namespace std;

int main()
{
	int **p;//新建一个二级指针p,即指向指针的指针
	p = new int*[3];//开辟3个【用来存储指针(即地址)】的空间,{ p[0] p[1] p[2] },其中p→p[0]
	*p = new int[12];//开辟12个【用来存储整形】的空间,{ ⑴ ⑵ ⑶ ⑷ ⑸ ⑹ ⑺ ⑻ ⑼ ⑽ ⑾ ⑿ }其中p[0]→⑴
	p[1] = p[0] + 4;//让p[1]→⑸ 
	p[2] = p[1] + 4;//让p[1]→⑼ 
	int i, j, k = 1;
	int *q;//新建一个指针q,目的在于让q移动而不是让p移动,p必须保证位置不动,方便后面释放内存
	q = p[0];//指针q赋值为p[0]的内容,即q→⑴
	for (i = 0; i<12; ++i){//由于内存是连续的,通过q++来移动指针进行【从1到12】的赋值
		*q = k;
		q++;
		k++;

	}
	for (i = 0; i<3; ++i){
		for (j = 0; j<4; ++j){
			cout << p[i][j] << endl;//p[i][j]=(p[i])[j],把p[i]看成一个整体,“[]”可以看成取值符号“*”
		}//即p[0][0]=**p,以此类推
	}

	delete[] p[0];//或者delete[] *p
	delete[] p;//先delete p[0]再delete p

	return 0;
}



运行效果如下:


声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。