C++ 二级指针和二维数组

来源:互联网 发布:软件测试x模型 编辑:程序博客网 时间:2024/05/16 10:36

首先很明确的一点是:二级指针不等于二维数组。

虽然可以把二维指针当做二维数组使用,但是它们的"寻址方式"是不一样的。看如下代码:

#include<iostream>int main(){int **p;int cp[3][3];for (int i = 0; i < 3; i++){for (int j = 0; j < 3; j++){cp[i][j] = i * 3 + j;}}p = reinterpret_cast<int**>(cp);printf("%d\n", cp[0][2]);        printf("%d\n", p[0][2]);        }

首先初始化 cp 为 0-8.

然后希望通过不同的防止输出cp的0行2列的值(应该为 2)

第一行 printf 输出 2,但是第二行会出错:0xC0000005: Access violation reading location 0x00000008.

这是因为二维数组的存储其实是按照一维数组的方式连续存储的。

对于数组 cp[0][2] 寻找的是第 0 行第二列的元素的值,也就相当于内存地址:cp + 0 * 3 + 2 上面存储的值。

然而如果cp 是二级指针,即上述代码中的p,则编译器对 p[0][2] 的解码是:首先把 p 当做是一个普通的指针,找到p[0] 的地址(p+0)后,再把 p[0] 里面存放的值 p1 = 0 当做是一个指针,然后在 p1 上进行下一次的寻址:p1[2] 对应的地址是:p1 + 2 .所以最后程序输出的是内存地址:p1 + 2 中存储的值,因为 p1 是一个指针,假设 sizeof p1 = 4,则有 p1+2 = 8(注意指针相加规则),因此 p[0][2] 读取的是地址 0x00000008 上面的值。

0 0
原创粉丝点击