#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]这种方式占用相同大小空间, //避免使用指针数组模拟二维数组时地址可能不连续和空间浪费问题 }
原文地址:http://blog.csdn.net/qingchunweiliang/article/details/35917387