c语言那些细节之a+1和&a+1的区别
来源:互联网 发布:小学生编程比赛 编辑:程序博客网 时间:2024/05/21 10:42
转子:http://blog.csdn.net/eastmoon502136/article/details/8630790
首先a是一个数组名,当看到这个a与&a时,一般我们的理解都是这个数组的首地址。没错,如果加上打印的话,确实两个值是一样的。
不过&a是整个数组的首地址,a则是数组首元素的地址,虽然值一样,但是意义却不相同。
在此之前有必要先看下c程序在内存中的分布图。
下面来看一个例子吧还是。
示例代码:
- #include <stdio.h>
- int main(int argc, char *argv[])
- {
- int i;
- int a[]={1, 2, 3, 4, 5};
- int s;
- int *p = (int *)(&a+1);
- printf(" a = %p\n&a = %p\n", a, &a);
- for(i = 0; i < 5; i++)
- printf("a[%d] = %p\n", i, &a[i]);
- printf(" p = %p\n&p = %p\n&s = %p\n", p, &p, &s);
- return 0;
- }
运行结果:
- a = 0022FF40
- &a = 0022FF40
- a[0] = 0022FF40
- a[1] = 0022FF44
- a[2] = 0022FF48
- a[3] = 0022FF4C
- a[4] = 0022FF50
- p = 0022FF54
- &p = 0022FF38
- &s = 0022FF3C
由上面的运行结果,我们可以知道a和&a的区别了。可得下图:
因为是运行在main函数体内的变量,所以这些都是在栈中运行的,所以p指针是指向了a[4]后的那个地址,而p本身的地址是在栈中分配的。
综上可知:
- &a+i = a + i*sizeof(a);
- a+i = a +i*sizeof(a[0]);
&a+1不是首地址+1,系统会认为加了一个整个a数组,偏移了整个数组a的大小(也就是5个int的大小)。所以int *ptr=(int *)(&a+1);其实ptr实际是&(a[5]),也就是a+5.
原因为何呢?
&a是数组指针,其类型为int(*)[5];
而指针加1要根据指针类型加上一定的值,不同类型的指针+1之后增加的大小不同,a是长度为5的int数组指针,所以要加5*sizeof(int),所以ptr实际是a[5],但是ptr与(&a+1)类型是不一样的,这点非常重要,所以ptr-1只会减去sizeof(int*),a,&a的地址是一样的,但意思就不一样了,a是数组首地址,也就是a[0]的地址,&a是对象(数组)首地址,a+1是数组下一元素的地址,即a[1],&a+1是下一个对象的地址,即a[5]。
0 0
- c语言那些细节之a+1和&a+1的区别
- c语言那些细节之a+1和&a+1的区别 .
- c语言那些细节之a+1和&a+1的区别
- c语言那些细节之a+1和&a+1的区别
- c语言那些细节之a+1和&a+1的区别
- (转+原创)c语言那些细节之a+1和&a+1的区别 ,指针的步长问题。
- C语言中 a-- 和a-1 的区别
- 程序猿之--C语言细节13(二维数组和指针,&*a[i][0]的理解,数组1[e]和e[1]很可能你没见过)
- 程序猿之--C语言细节13(二维数组和指针,&*a[i][0]的理解,数组1[e]和e[1]很可能你没见过)
- c语言的 a++ 和 ++a有什么区别
- c语言整理数组a和&a的区别
- (int&)a和(int)a的区别 - c语言
- C语言中的++a和a++的区别
- C语言中Node * a,和Node* &a的区别
- C语言中的++a和a++的区别
- C语言之旅(10)a++和++a的区别
- c语言那些细节之little-endian和big-endian
- C++: A a() 和 A a 的区别。
- OpenWRT 增加内核模块及应用方法
- Java编程算法基础--面向对象的设计原则
- Spring的事务管理难点剖析(3):事务方法嵌套调用的迷茫
- openstack 不适合做公有云
- >/dev/null 2>&1 含义
- c语言那些细节之a+1和&a+1的区别
- Python 代码规范检查
- Redis 如何处理客户端连接
- LevelDB源码剖析之SSTable_sstable文件的读取
- Liferay中Portal.properties常用配置参数
- 黑马_blog2_坦克大战游戏代码
- Http协议三次握手
- 根据metalink脚本学习undo(五)
- HDU 1075 What Are You Talking About (map解法+Trie解法)