#include<iostream>
using namespace std;
//动态开辟int p[4][5]数组
void main()
{
//为了验证正确性,我们先把开辟的一维数组赋值给 pp
int *pp=new int[20];
int i=0,j=0;
for(i=0;i<20;i++)//为一维数组中每一个元素赋值,并输出该元素地址
{
pp[i]=i;
cout<<&(pp[i])<<" ";//即 pp+i
}
cout<<endl;
int (* const p)[5]=(int(*)[5])pp;//转为二维常指针
//p=(int(*)[5])pp; p已经是数组首地址,企图修改该常量会报错(const限定为常量)
for(i=0;i<4;i++)//依次输出二维数组中每一个元素的值
for(j=0;j<5;j++)
cout<<p[i][j]<<" ";
cout<<endl;
for(i=0;i<4;i++)//依次输出二维数组中每一个元素的地址,可以看出地址是连续的
for(j=0;j<5;j++)
cout<<&(p[i][j])<<" ";
cout<<endl;
//上面开辟二维数组可以简化为 int (* const p)[5]=(int(*)[5])(new int[20]);
//优点 : 只使用了20个int型大小的空间,加一个指针,与用int p[4][5]这种方式占用相同大小空间,
//避免使用指针数组模拟二维数组时地址可能不连续和空间浪费问题
}
一句话动态开辟二维数组
最新推荐文章于 2023-12-20 15:58:10 发布