本帖最后由 奥普瓯江 于 2017-6-30 17:29 编辑
这道题我明白了,因为pa是变量他的值*pa++后(pa是先于++相结合在于*号结合的),所以pa的值被覆盖了,并储存在某个地方的,具体哪地方叫什么名字我不是很确定,所以我后面想用下面的程序打印是打印不了的for( i = 0; i < 3; i++)
{
printf("%c", *( pa + i ))
}
如果想打印相同的值那我就必须把pa初始化让他与arr数组相等不然指针就找不到数组,因为每个指针的内存地址都加了响应的值,向下面这个这个程序每个指针地址都加了3,如果不初始化他就找不到数组。
这个程序我是这么改的#include<stdio.h>
int main(void)
{
char arr[] = {1, 2, 3};
char *pa = arr;
int i;
printf("&arr[0] = %p\n", &arr[0]);
printf("&arr[1] = %p\n", &arr[1]);
printf("&arr[2] = %p\n", &arr[2]);
printf("**************************\n");
printf("pa = %p\n", pa);
*pa++;
printf("pa = %p\n", pa);
*pa++;
printf("pa = %p\n", pa);
printf("******************\n");
pa = arr; //arr得值从新赋给指针的变量pa
for ( i = 0; i < 3; i++ )
{
printf("%p\n", &pa[i] );
printf("%d\n", *(pa + i));
}
return 0;
}
下面是arr得值从新赋给了pa所打印出来的值&arr[0] = 0xbfbd1e09
&arr[1] = 0xbfbd1e0a
&arr[2] = 0xbfbd1e0b
**************************
pa = 0xbfbd1e09
pa = 0xbfbd1e0a
pa = 0xbfbd1e0b
******************
0xbfbd1e09
1
0xbfbd1e0a
2
0xbfbd1e0b
3
下面是arr没有从新赋给了pa所打印出来的值,每个内存地址比原有的内存地址数加3个&arr[0] = 0xbfc99709
&arr[1] = 0xbfc9970a
&arr[2] = 0xbfc9970b
**************************
pa = 0xbfc99709
pa = 0xbfc9970a
pa = 0xbfc9970b
******************
pa = 0xbfc9970b
pa = 0xbfc9970c
pa = 0xbfc9970d
|