zoukankan      html  css  js  c++  java
  • int *ptr=(int *)(&a+1)问题的探讨

    从网络上看到这样一道有意思的题目,是关于数组与指针的问题,描述如下:

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

    输出为:2,5

    请解释以上代码的输出结果。

    答案如下:

    *(a+1)其实很简单就是指a[1],输出为2.

    问题关键就在于第二个点,*(ptr-1)输出为多少?

    解释如下,&a+1不是首地址+1,系统会认为加了一个整个a数组,偏移了整个数组a的大小(也就是5个int的大小)。所以int *ptr=(int *)(&a+1);其实ptr实际是&(a[5]),也就是a+5.

    原因为何呢?

    数组名a是一个地址常量,&a是数组指针,其类型为int(*)[5],也就是指向int[5]这个类型的一个指针;

    而指针加1要根据指针类型加上一定的值,不同类型的指针+1之后增加的大小不同,a是长度为5的int数组指针,所以要加5*sizeof(int),所 以ptr实际是a[5],但是ptr与(&a+1)类型是不一样的,这点非常重要,所以ptr-1只会减去 sizeof(int*),a,&a的地址是一样的,但意思就不一样了,a是数组首地址,也就是a[0]的地址,&a是对象(数组)首地 址,a+1是数组下一元素的地址,即a[1],&a+1是下一个对象的地址,即a[5]。

     

    另外一个例子,方便看出地址的区别:

    int main(int argc, char *argv[])
    {
        int i;
        int a[]={1, 2, 3, 4, 5};
        int s;
        int *p = (int *)(&a+1);
        printf(" a = %p
    &a = %p
    ", a, &a);
        for(i = 0; i < 5; i++)
            printf("a[%d] = %p
    ", i, &a[i]);
        printf(" p = %p
    &p = %p
    &s = %p
    ", p, &p, &s);
        return 0;
    }
  • 相关阅读:
    前端有未来吗?
    谈技术人员思维转变
    程序员职场背锅甩锅指南
    9 个非常实用的网络调试命令,你会用几个呢?
    nginx获取客户端请求的真实IP
    10个VSCode高效开发插件
    作为一个技术Leader,要如何去提升团队的技术氛围
    前端程序员要懂的 UI 设计知识
    【云速建站】如何实现多用户权限管理
    补习系列(10)-springboot 之配置读取
  • 原文地址:https://www.cnblogs.com/fightformylife/p/4065129.html
Copyright © 2011-2022 走看看