walter_¥ 2019-09-16 11:30 采纳率: 100%
浏览 207
已采纳

Linux中C语言问题。。。。。。

我在ubuntu32位机器中运行以下程序

#include <stdio.h>

int main(void)
{

        int a=12;int *p,*q,*r;
        p=&a;
        r=p+1;
        q=p++;
        printf("%p\r\n%p\r\n%p\r\n",p,q,r);
        printf("%2d%2d\n",q-p,r-p);
        printf("%5d\n",(char*)p-(char*)q);
        printf("%p\n%p\n",(char*)p,(char*)q);
        return 0;
}

得出以下结果

图片说明

求大神解释一下,为什么会是这样一个结果。

  • 写回答

3条回答

  • hglzw 2019-09-16 15:35
    关注

    q=p++,是先执行q=p,再执行p+1;而q=++p;就是先加而后赋值了。
    指针执行+1操作,地址到底加多少就是要看指针指向的数据类型是什么样子的,比如开始你定义了int*;int在32位系统中认为是32位的,那么这个指针指向的数据单元类型就是32位的,指针执行+1的操作,就是代表指向下一个存储单元,所以存贮地址-4.(注:存储地址的分配是按字节可寻址来规划的。)后来强制把指针转化成char*后,代表指针指向的数据类型为char类型,那么4个存储字节的跨度,指针就相差4个了。
    int *p;p存的就是存数据的单元地址(但是P+1却不是地址直接加1,这里有点别扭,这里是按单元的单位算的,一个单元就是一个数据类型的尺寸);*p是数据的值;&p就是存数据地址的地址,就是指针本身的地址。

    后补:p=r这个结果没毛病,先是r=p+1;而后又执行了q=p++;那么r比最早的p多出1单元。而p++以后,现在的p也比最早的p加了1单元,所以最后r和p就是一样的了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 求学软件的前人们指明方向🥺
  • ¥50 如何增强飞上天的树莓派的热点信号强度,以使得笔记本可以在地面实现远程桌面连接
  • ¥15 MCNP里如何定义多个源?
  • ¥20 双层网络上信息-疾病传播
  • ¥50 paddlepaddle pinn
  • ¥20 idea运行测试代码报错问题
  • ¥15 网络监控:网络故障告警通知
  • ¥15 django项目运行报编码错误
  • ¥15 STM32驱动继电器
  • ¥15 Windows server update services