C/C++ 关于数组的指针和数组元素首地址的一道经典题
来源:互联网 发布:新开的淘宝店如何推广 编辑:程序博客网 时间:2024/06/05 17:27
#include <stdio.h> int main(void) { int a[5] = {1, 2, 3, 4, 5}; int *ptr = (int *)(&a+1); int *p1 = a; int *p2 = &a[0]; int *p3 = (int *)(&a); if(p1 == p2){ printf("p1 == p2\n"); }else{ printf("p1 != p2\n"); } if(p1 == p3){ printf("p1 == p3\n"); }else{ printf("p1 != p3\n"); } if(p2 == p3){ printf("p2 == p3\n"); }else{ printf("p2 != p3\n"); } printf("%d %d\n",*(a+1),*(ptr-1)); int *p4 = ++p1; int *p5 = ++p3; if(p4 == p5){ printf("p4 == p5\n"); }else{ printf("p4 != p5\n"); } return 0; }最终输出结果如下:
里面所有的判断都是相等,打印的两个值是2和5.
原因如下:
&a是数组的首地址,它的类型是int(*)[5],因此+1是加的是数组个数的步长。指针加1要根据指针自身类型加上一定的值, 不同类型的指针+1之后增加的大小不同。因此&a + 1后指向的地址对数组来说是越界的,注意前面有个int(*)又强制将他转为int*了。因此计算*(ptr - 1)的时候,ptr是个int类型的指针,减一等于往左移动sizeof(int*)个字节,因此又指向a[4]了,他的值等于&a[4].
为此杂家又对p4和p5作了验证,为啥结果p4会等于p5呢?原因就在于申请p3的时候对&a进行了强制类型转换,
int *p3 = (int *)(&a);
如果不加这个转换,是编译不过去的。加了转换之后p3等于p1也等于p2,他的类型跟另外两个一样都是int*类型的了,因此移动相同位后地址也是一样的。很多人纠结就纠结在&a、a、&a[0],根本原因在于对&a进行了强制类型(int*)转换。
阅读全文
0 0
- C/C++拾遗:关于数组的指针和数组元素首地址的一道经典题
- C/C++ 关于数组的指针和数组元素首地址的一道经典题
- C/C++拾遗(一):关于数组的指针和数组元素首地址的一道经典题
- 一道关于二维数组和指针数组的C语言笔试题目
- 关于C数组指针的一道面试题
- 关于数组指针的一道题
- 【C】 一道题浅尝指针数组和二级指针
- 从一道C语言数组指针的笔试题看面试者的能力和心态
- 【重新上本科】从一道笔试题来看数组和指针的区别(c++)
- C语言指针、数组的使用和内存地址
- c语言中数组中的地址和指针的关系
- C/C++中关于地址、指针和引用变量的学习笔记(二) : 数组
- 再议C/C++中关于指针、地址和多维数组的关系
- 彻底搞清C/C++中一维数组,二维数组,指针,数组指针和指针数组以及指向指针的指针,行地址和列地址之间的关系
- 彻底搞清C/C++中一维数组,二维数组,指针,数组指针和指针数组以及指向指针的指针,行地址和列地址之间的关系
- C语言二维数组剖析【元素及元素地址的指针操作】
- C语言学习笔记之指向数组元素的指针和指向数组的指针
- 指针和数组equal的一道题
- 点到平面的距离
- G1垃圾回收器
- Leetcode之Rotate Array 问题
- HDU2057 A + B Again
- Yii2.0 汉化(国际化)
- C/C++ 关于数组的指针和数组元素首地址的一道经典题
- 状态模式
- 视频的帧率和分辨率以及码率的关系
- C#回顾学习笔记二十八:装箱和拆箱
- Spring 事务配置管理,简单易懂,详细 [声明式]
- avro 生成java bean
- 【GDOI2018模拟9.21】数列
- [agc012d]Colorful Balls
- hive 查询结果压缩