C语言数组中的地址偏移问题
2013-06-24 15:04
239 查看
本文讨论在C/C++中,一维数组和二维数组中的地址偏移问题。
一维数组 int a[3];
二维数组 int a[3][3];
1、先看一维数组的情况:
从结果中可以看出,&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、二维数组的情况
结果分析:
&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代表着二维数组中第三级别的地址。
一维数组 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语言数组与函数问题归纳
- 关于包含0长数组的结构体对齐问题(C语言 Linux_x64 GNU编译器)
- C语言数组和指针的理解_在取地址运算上的操作_指针加减操作_a 和&a 的区别
- C语言的一个笔试题:指针与数组的问题
- c语言中的一些问题(scanf循环、三维数组做形参)
- C语言--对数组地址的解析
- 一个看似简单的数组地址问题
- 一个关于去除数组重复元素的问题(C语言实现)
- C语言多维数组的地址