C语言数组中的地址偏移问题

来源:互联网 发布:把多个excel表数据合并 编辑:程序博客网 时间:2024/04/28 03:29

本文讨论在C/C++中,一维数组和二维数组中的地址偏移问题。

一维数组 int a[3];

二维数组 int a[3][3];


1、先看一维数组的情况:

#include <iostream>using namespace std;int main(){int a[3] = {1,2,3};cout << &a << endl;cout << a << endl;cout << &a[0] << endl;cout << a[0] << endl;cout << &a + 1 << endl;cout << a + 1 << endl;cout << &a[0] + 1 << endl;cout << a[0] + 1 << endl;system("pause");return 0;}


从结果中可以看出,&a、a、&a[0]表示的是同一地址,但是级别是不一样的。

&a+1地址与&a相比,偏移了12个字节,即声明数组的空间大小;

a+1地址与a相比,偏移了4个字节,即数组中一个元素的空间大小

&a[0]+1地址与&a[0]相比,偏移了4个字节,即数组中一个元素的空间大小

也就说&a、a、&a[0]虽然都表示同一地址,但是编译器会区分它们,&a指向整个数组的地址,是数组中最高级别的地址,而a和&a[0]表示&a代表地址的下一级别的地址。


2、二维数组的情况

#include <iostream>using namespace std;int main(){int a[3][3] = {{1,2,3},{4,5,6},{7,8,9}};cout << &a << endl;cout << a << endl;cout << &a[0] << endl;cout << a[0] << endl;cout << &a[0][0] << endl;cout << a[0][0] << endl;cout << &a + 1 << endl; cout << a + 1 << endl;cout << &a[0] + 1 << endl;cout << a[0] + 1 << endl;cout << &a[0][0] + 1 << endl;cout << a[0][0] + 1 << endl;system("pause");return 0;}


结果分析:

&a、a、&a[0]、a[0]、&a[0][0]表示的是同一地址,但是级别差距很大。

声明的 int a[3][3] 大小为36字节。

&a+1地址与&a相比,偏移了36个字节,即声明数组的空间大小;

a+1地址与a相比,偏移了12个字节,即数组中一行元素的空间大小;

&a[0]+1地址与&a[0]相比,偏移了12个字节,即数组中一行元素的空间大小

a[0]+1地址与a[0]相比,偏移了4个字节,即数组中一个元素的空间大小

&a[0][0]+1地址与&a[0][0]相比,偏移了4个字节,即数组中一个元素的空间大小;

由以上可以看出,&a是最高级别的地址,a+1与&a[0]+1是第二级别的地址,a[0]+1与&a[0][0]+1代表着二维数组中第三级别的地址。



原创粉丝点击