代码
该部分代码的exam2返回的字符串无法正常打印(建议先思考再看分析)
#include <stdio.h>
char *exam1(){
char *p;
p="i love you";
return p;
}
char *exam2(){
char *p;
char ch[] = "nice to see you";
//puts(p);
p = ch;
//puts(ch);
return p;
}
int main(){
char *pc;
pc = exam1();
puts(pc);
printf("*p=%s\n",pc);
pc = exam2();
puts(pc);
printf("*p=%s\n",pc);
}
效果图
如图,第一次的i love you打印成功,但第二次的nice to see you却变成乱码。
分析
从表面上看,exam1与exam2都是将一个字符串赋值给了指针p。正常而言两个函数返回的指针都是指向了一个字符串的地址,在main方法中打印理应正常。
再来分析代码:
exam1:
char *p;
p="i love you";
exam2:
char *p;
char ch[] = "nice to see you";
p = ch;
两者的区别在于exam1中字符串是直接赋值一个字符串,而exam2中字符串先赋值到一个字符数组里面再让指针指向这个字符数组。
其中exam1的"i love you"是一个常量,它在编译时已被分配到静态数据区,而指针p指向它返回后在main方法中便可以正常打印。
而exam2中的"nice to see you"是先赋值给一个局部变量ch[],再将p指向这个局部变量的地址。虽然如果在函数内部打印(exam2内注释代码)可正常打印,到了main方法中由于局部变量的生命在函数结束时同时结束,导致指针虽然指向该地址但内部已经没有数据而无法正常打印"nice to see you"。
涉及的知识点
1、指针
2、局部变量
3、字符串
一些看起来极其基础的知识点,如果不是基础十分扎实却也无法轻易解出该题吧。
一些后话
在上课中老师讲“我写这个i love you”是有意义的,不是随便写的。想了半天这个“i love you”和“nice to see you”有什么区别。结果再最后给我们解释说“爱是永远不变的嘛,放在静态区只要你程序还活着这份爱就不会变。”
“emmmm,不愧是你”
“强无敌”