传递动态内存

来源:互联网 发布:虚拟狙击软件 编辑:程序博客网 时间:2024/05/23 13:01
.Double dArray[2] = {3,9},*p,*q;p=&dArrary[0];q=p+1;cout<<q-p<<(int)q-(int)p;
答案:1 8


分析:q-p的实际运算是:(q的地址-p的地址)/sizeof(double)

原题:

  main()  {    int a[5]={1,2,3,4,5};    int *ptr=(int *)(&a+1);    printf("%d,%d",*(a+1),*(ptr-1));  }



  程序输出是什么。

解答:
  程序输出: 2,5

分析:
  这里主要是考查关于指针加减操作的理解。
  对指针进行加1操作,得到的是下一个元素的地址,而不是原有地址值直接加1。所以,一个类型为 T 的指针的移动,以 sizeof(T) 为移动单位。

  因此,对上题来说,a是一个一维数组,数组中有5个元素; ptr 是一个 int 型的指针。
  &a + 1: 取 a 的地址,该地址的值加上 sizeof(a) 的值,即 &a + 5*sizeof(int),也就是 a[5] 的地址,显然当前指针已经越过了数组的界限。
  (int *)(&a+1): 则是把上一步计算出来的地址,强制转换为 int * 类型,赋值给 ptr。


  *(a+1):  a,&a的地址是一样的,但意思不一样,a是数组首地址,也就是a[0]的地址,&a是对象(数组)首地址,a+1是数组下一元素的地址,即a[1],&a+1是下一个对象的地址,即a[5]。所以输出2

  修改:*(a+1): 输出2。 分析:a,&a的地址是一样的,但意思不一样,a是数组首地址,也就是a[0]的地址,&a是对象(数组)首地址,a+1是数组下一元素的地址,即a[1],&a+1是下一个对象的地址,即a[5]。


  *(ptr-1): 因为 ptr 是指向 a[5],并且 ptr 是 int * 类型,所以 *(ptr-1) 是指向 a[4] ,输出5。

0 0