注册 登录
编程论坛 数据结构与算法

这道题的结果是多少啊,望指教!

feixiang1231 发布于 2010-12-10 13:50, 692 次点击
#include<stdio.h>

int main()
{
    int*p,
        *q;
    int c;
    int a[]={10,20,30,40};
    p=&a[0],q=&a[3];
    c=q-p;

        printf("%d\n",c);
return 0;
}
程序算出c=3, 为什么等于3啊,p和q不都a是地址吗,int类型变量是4个字节,p=a+1*4,从第一个元素到第四个一共是12个字节,结构应该等于12啊
请大家指点一下,谢谢

[ 本帖最后由 feixiang1231 于 2010-12-10 13:51 编辑 ]
5 回复
#2
li_danwang2010-12-10 14:07
两个指针变量指向同一个数组的中元素时候,俩指针变量相减,表示俩指针之间元素的个数
#3
jiasenlin2010-12-10 16:29
结果是 3吗?  不是三十吗?
#4
寒风中的细雨2010-12-10 16:46
要理解这点 可以间接地来看
int *p=NULL;
int a[] = {10,20,30,40};
 p = a;
 ++p;//这句的含义
#5
落拓2010-12-11 16:41
楼主看看这代码
#include<stdio.h>
struct std
{
    int data;
    struct std *next;
};

void  main()
{
    int *p= NULL;
    char *c= NULL;
    float *f= NULL;
    struct std *s=NULL;

    printf("%d %d %d %d",sizeof(p),sizeof(c),sizeof(f),sizeof(s));

}
猜猜输出是什么。

是清一色的 4。很奇怪吧。从输出看,不同类型的指针,占的内存是一样的。这样的话,区分指针的类型似乎没什么用。
区分的作用是,当运行 p= p + 1 时,p应该向后移动多少位!这就必须靠p所指向的数据类型来决定。
这就说明,p + 1 不是一个字节一个字节地移动的。而是向后移动多位。相减是它的一个逆过程。
#6
渊奇绝2010-12-13 18:10
指针移动的一个单位等于声明的类型的字节长
1