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代表着二维数组中第三级别的地址。
- C语言数组中的地址偏移问题
- C语言数组中的地址偏移问题
- C语言数组中的地址偏移问题
- C语言数组首地址问题
- C语言--数组首地址问题小记
- C语言编译数组地址分配问题
- C语言中数组与指针偏移
- 【C语言】数组名&地址&地址中的值的访问
- C语言中的指针加减偏移量
- C语言中的指针加减偏移量
- C语言中的指针加减偏移量
- C语言中的指针加减偏移量
- C++数组地址偏移
- c语言数组地址
- C语言中的经典问题之数组
- C语言中的数组初始化问题
- C语言二维数组中的指针问题
- c语言中数组中的地址和指针的关系
- android-包签名
- jenkins核心开发人员是川口浩介 Kohsuke Kawaguchi
- 黑马程序员——java学习10(IO流)
- jquery子元素过滤选择器
- makefile study
- C语言数组中的地址偏移问题
- 遗传算法工具箱的应用
- 编程SocketJavathread.net
- 面向GPU并行计算新趋势
- css画竖线
- Creating a List Item instance programmatically using the object model
- QML基本元素介绍
- 人生三境界
- bash: hadoop: command not found