今天测了一个程序,发现了一些不懂的问题,下面贴上代码和自己的一些想法。
1.用指针指向一个字符串,并尝试修改字符串。
char *p = "hello";
p[2] = 'c';
printf("the word is :%s\n",p);
编译没有问题,但是运行没有任何的输出。
我们都知道p指向“hello”的首字母‘h’的地址,但printf("the word is :%s\n",p);可以输出hello .但是修改其中一个字母导致无法输出这个字符串。
所以我想是不是应该是这样的:p指向h的地址,而h的内存中储存着指向e的地址,在输出h后,将其重新赋值给p。然后一次p→h→e→l→l→o→\0;
当改变其中一个字符被修改后,导致内存中无法对p进行重新赋值,导致无法输出字符串;
2.对上面的程序进行修改
char c[ ] = “hello”;
char *p =c;
p[2] = 'c';
printf("the word is: %s\n",p);
编译没问题,运行输出heclo,运行成功;
所以我在想,p指向的是c[0]的地址,而c[0]中存储着h。c中存在着上面第一个程序p的特性,每个地址中会存储下一个字符所在的地址。但是c到p存在的是一个映射关系
p只是逐个指向c,c[1]...c[4].所以定义p[2]为c时,p指向c[2]时并未提取l,而是将重新赋值指向c[3],然后继续赋值。
总结:上面的一些只是我经过测试之后的一些设想,希望大家纠错指点。