new一个动态二维数组并实现内存连续
#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; }
运行效果如下:
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。