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个回答

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就是一样的了。

weixin_40700617
淦123 谢谢
7 个月之前 回复
hglzw
hglzw 回复淦123: 一开始没仔细看清楚,后来又修改了一下。这个结果没毛病,先是r=p+1;而后又执行了q=p++;那么r比最早的p多出1单元。而p++以后,现在的p也比最在的p加了1单元,所以最后r和p就是一样的了。
7 个月之前 回复
weixin_40700617
淦123 代码里面是r=p+1;可是我运行出来的结果是p和r的值是一样的。。
7 个月之前 回复

32bit的指针是4个字节(32/8=4),也就是8个16进制数,没毛病啊。

caozhy
每个人都有一个梦才不会孤单的说话就有天堂 回复淦123: 这个内存的分布是特定编译器决定的
7 个月之前 回复
weixin_40700617
淦123 我想问问,为什么r和p的值一样,为什么q-p等于-1,为什么p和q强转之后相减等于4?
7 个月之前 回复

同意楼上说法,题主想问啥

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问