指针一个不容易发现的错误
#include <stdio.h>void main()
{
int *p, i, a;
p = a;
for(i=0; i<10; i++)
{
scanf("%d", p++);
}
printf("\n");
for(i=0; i<10; i++, p++)
{
printf("%d\n", *p);
}
}
我知道错误是因为第一个for循环将p的值增加了十次,但第一个for循环结束后p到底是个什么东西? 第二个for循环前面加个p = a 本帖最后由 巴巴鲁 于 2021-2-27 08:56 编辑
指针本质上是地址(我是这样理解的)
就比如,a数组的首地址是6422220,那么
a的地址6422220
a的6422224
a的6422228
a的6422232
a的6422236
a的6422240
a的6422244
a的6422248
a的6422252
a的6422256
所以第一个for循环完后,p的值会在a地址的基础上+4,就是6422260这个地址(+4的原因就是1个int类型占4个字节)
但是6422260的内存空间没有给赋值,如果想访问,系统会自动赋一个值 叙白 发表于 2021-2-27 00:33
第二个for循环前面加个p = a
我知道这样可以修改错误,但我想知道第一个for循环结束后,p代表的是什么 巴巴鲁 发表于 2021-2-27 08:55
指针本质上是地址(我是这样理解的)
就比如,a数组的首地址是6422220,那么
a的地址6422220
第一个for循环不是把a到a都赋值了吗,为什么第二个for循环打印出来的不是a到a的值,是因为第一个for循环结束后p不等于a了吗?如果p不等于a了,那能不能知道p等于什么? 巴巴鲁 发表于 2021-2-27 08:55
指针本质上是地址(我是这样理解的)
就比如,a数组的首地址是6422220,那么
a的地址6422220
好像知道了,第一个for循环结束后p变成了p+10 siaj 发表于 2021-2-27 10:59
好像知道了,第一个for循环结束后p变成了p+10
也不完全对,如果是char类型数组,循环完后是p+10
int、float类型是p+40
double是9+80
这个取决于数组的类型
页:
[1]