|

楼主 |
发表于 2017-6-30 17:09:35
|
显示全部楼层
本帖最后由 奥普瓯江 于 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
复制代码 |
|