Chinaunix首页 | 论坛 | 博客
  • 博客访问: 209971
  • 博文数量: 87
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 798
  • 用 户 组: 普通用户
  • 注册时间: 2015-01-14 14:54
文章分类

全部博文(87)

文章存档

2015年(87)

我的朋友

分类: C/C++

2015-03-20 10:33:52


首先a是一个数组名,当看到这个a&a时,一般我们的理解都是这个数组的首地址。没错,如果加上打印的话,确实两个值是一样的。

不过&a是整个数组的首地址,a则是数组首元素的地址,虽然值一样,但是意义却不相同。

下面来看一个例子吧还是。


示例代码:

[html] view plaincopy
  1. #include <stdio.h>  
  2. int main(int argc, char *argv[])  
  3. {  
  4.     int i;  
  5.     int a[]={1, 2, 3, 4, 5};  
  6.     int s;  
  7.     int *p = (int *)(&a+1);  
  8.     printf(" a = %p\n&a = %p\n", a, &a);  
  9.     for(i = 0; i < 5; i++)  
  10.         printf("a[%d] = %p\n", i, &a[i]);  
  11.     printf(" p = %p\n&p = %p\n&s = %p\n", p, &p, &s);  
  12.     return 0;  
  13. }  


运行结果:

 

[html] view plaincopy
  1. a = 0022FF40  
  2. &a = 0022FF40  
  3. a[0] = 0022FF40  
  4. a[1] = 0022FF44  
  5. a[2] = 0022FF48  
  6. a[3] = 0022FF4C  
  7. a[4] = 0022FF50  
  8.  p = 0022FF54  
  9. &p = 0022FF38  
  10. &s = 0022FF3C  



由上面的运行结果,我们可以知道a&a的区别了。可得下图:



因为是运行在main函数体内的变量,所以这些都是在栈中运行的,所以p指针是指向了a[4]后的那个地址,而p本身的地址是在栈中分配的。

综上可知:

[html] view plaincopy
  1. &a+i = (unsigned int)&a + i*sizeof(*&a);  
  2. a+i = (unsigned int)a +i*sizeof(*a);     (此结论来自国嵌视频)
阅读(1169) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~