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 矩阵加法的规则是两个矩阵中对应位置的数的绝对值进行加和
  • ¥15 活动选择题。最多可以参加几个项目?
  • ¥15 飞机曲面部件如机翼,壁板等具体的孔位模型
  • ¥15 vs2019中数据导出问题
  • ¥20 云服务Linux系统TCP-MSS值修改?
  • ¥20 关于#单片机#的问题:项目:使用模拟iic与ov2640通讯环境:F407问题:读取的ID号总是0xff,自己调了调发现在读从机数据时,SDA线上并未有信号变化(语言-c语言)
  • ¥20 怎么在stm32门禁成品上增加查询记录功能
  • ¥15 Source insight编写代码后使用CCS5.2版本import之后,代码跳到注释行里面
  • ¥50 NT4.0系统 STOP:0X0000007B
  • ¥15 想问一下stata17中这段代码哪里有问题呀