我在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;
}
得出以下结果
求大神解释一下,为什么会是这样一个结果。
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就是一样的了。
32bit的指针是4个字节(32/8=4),也就是8个16进制数,没毛病啊。
同意楼上说法,题主想问啥