posts - 13,  comments - 16,  trackbacks - 0
int main()
{
int a[5]={1,2,3,4,5};
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);
// 同理,(int)a先将其值(地址)转为整型值,再加一成为一个新的整数
// (int *)将这个值转换为一个指向int型变量的指针(地址)
// ptr2即存储了这个地址和指向的变量的类型

printf("%x,%x",ptr1[-1],*ptr2);
// 先解释一下a[-1],即将数组向前偏差一个类型大小的距离
// 数组a的内存布局(16进制):01000000 02000000 03000000 04000000 05000000
// ptr1[-1]
// 你说这里等于什么呢?数组a最后一个元素(5)紧跟着一个int的前面一个元素当然就是5了。
// *ptr2
// ptr2的值为a保存的地址值的绝对值+1,假设a=1000,那么(int)a+1=1001。
// 而后将其再转为(int *)指针,那么指针指向的内存布局为000000 02,即向后移了一个字节
// 那么在little-enddian架构下显示出来为02000000,低位在高地址。

return 0;
}
posted on 2009-09-24 11:14 似水之心 阅读(402) 评论(0)  编辑 收藏 引用

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   博问   Chat2DB   管理



<2009年6月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

常用链接

留言簿(2)

随笔档案

文章档案

搜索

  •  

最新评论

阅读排行榜

评论排行榜