数组取址 和 ptr[-1]
来源:互联网 发布:ubuntu apu 编辑:程序博客网 时间:2024/06/10 18:23
int a[5]={1,2,3,4,5};
// 数组a的内存布局(16进制):01000000 02000000 03000000 04000000 05000000
int *ptr1=(int *)(&a+1);
// a本身就为一个数组的地址,其值=&a[0],即数组第一个元素的地址,对a再取址
// &a = a,似乎没什么不同,其实这里发生了对齐变更,a+1的对齐是以int为界的
// 而&a+1是以整个数组为单位的,即5个int=20字节,这是关键!!!
// 那么&a+1实际是跨越了整个数组,可得ptr1存储了数组a最后一个元素5紧跟着的一个int的地址
int *ptr2=(int *)((int)a+1);
// ptr2的值为a保存的地址值的绝对值+1,假设a=1000,那么(int)a+1=1001。
// 而后将其再转为(int *)指针,那么指针指向的内存布局为000000 02,即向后移了一个字节
// 那么在little-enddian架构下显示出来为02000000,低位在高地址。
int *ptr3=(int *)(a+1);
// a为数组首地址,a+1指向第二个元素
printf("%x,%x,%x\n",ptr1[-1],*ptr2,ptr3[-1]);
// 输出为:5,2000000,1
// 数组a的内存布局(16进制):01000000 02000000 03000000 04000000 05000000
int *ptr1=(int *)(&a+1);
// a本身就为一个数组的地址,其值=&a[0],即数组第一个元素的地址,对a再取址
// &a = a,似乎没什么不同,其实这里发生了对齐变更,a+1的对齐是以int为界的
// 而&a+1是以整个数组为单位的,即5个int=20字节,这是关键!!!
// 那么&a+1实际是跨越了整个数组,可得ptr1存储了数组a最后一个元素5紧跟着的一个int的地址
int *ptr2=(int *)((int)a+1);
// ptr2的值为a保存的地址值的绝对值+1,假设a=1000,那么(int)a+1=1001。
// 而后将其再转为(int *)指针,那么指针指向的内存布局为000000 02,即向后移了一个字节
// 那么在little-enddian架构下显示出来为02000000,低位在高地址。
int *ptr3=(int *)(a+1);
// a为数组首地址,a+1指向第二个元素
printf("%x,%x,%x\n",ptr1[-1],*ptr2,ptr3[-1]);
// 输出为:5,2000000,1
- 数组取址 和 ptr[-1]
- int *ptr=(int *)(&a+1),对数组名取地址是取的整个数组的地址
- 数组首元素地址和数组地址、int *ptr=(int *)(&a+1)问题的探讨
- ptr[-1]的作用和用法
- 多维数组a[x][y]的指针操作及ptr+1 a+1和&a+1区别
- 取数组最大和次大值
- 数组的存和取
- 数组名和数组名取地址
- 数组名和数组名取地址&
- 数组名和数组名取地址&
- 数组名和数组名取地址&
- 数组名和数组名取地址&
- 数组名和数组名取地址&
- 数组名和数组名取地址&
- 数组名和数组名取地址&
- 数组名和数组名取地址&
- ptr->a()和 (*ptr).a()有何不同
- C++ 智能指针shared-ptr,unique_ptr和weak-ptr
- ActivityGroup的子类中不能使用bindService的解决办法
- 关于爱情
- Box2D C++教程15-用户数据
- java中将map作为暂时性的存储容器,设置Map的size为10,大于10就删除
- Statement vs PreparedStatement
- 数组取址 和 ptr[-1]
- 深入理解指针
- androidpn-client修正服务器断开后重新链接重要代码
- 常用的stsadm命令行参数
- c++中关于数组作为函数参数并传递数组元素个数的几种有效方法的讨论
- sqlserver中创建链接服务器图解教程
- [转]微博能泄漏你生活上的大量信息,可能被人利用为对付你的工具
- debian 安装firefox 最新版
- 21种思维方式助你跻身富人阶层