关于子函数返回字符串问题集锦
来源:互联网 发布:apache curator下载 编辑:程序博客网 时间:2024/06/14 08:32
Case1:
#include<stdio.h>#include<string.h>#include<stdlib.h>char* getMem(void){ char p[] = "hello world";//这样子定义可以输出,但输出乱码。 p[5] = 0x0; return p;}int main(){ char *s="fzz"; s=getMem(); printf("%s\n",s); return 0;}
字符串数组p是个局部变量,存在栈内。当子函数返回时,栈空间也会被销毁。那么返回的字符串首地址p对应的内存保存的已经不是hello world了。而是未知的。因此输出乱码。
Case 2:
#include<stdio.h>#include<string.h>#include<stdlib.h>char* getMem(void){ static char p[] = "hello world";//可以输出,输出为hello; p[5] = 0x0; return p;}int main(){ char *s="fzz"; s=getMem(); printf("%s\n",s); return 0;}此处我们把字符串数组p定义为静态变量,存储在静态存储区。不随着子函数的返回而销毁。因此可以正常运行。
Case 3:
#include<stdio.h>#include<string.h>#include<stdlib.h>char* getMem(void){ char *p = "hello world";//程序运行时出错 不能输出 p[5] = 0x0; return p;}int main(){ char *s="fzz"; s=getMem(); printf("%s\n",s); return 0;}
这里不能输出和case1有点相像,但又并不完全一样。因为字符数组中各元素的值是可以改变的(可以对他们再赋值),但字符指针变量指向的字符串常量中的内容是不可以被改变的。这是因为在C语言中只有字符变量和字符串常量,没有字符串变量,而常量是不可以改变的。因此p[5]=0x0本身就是错误的。尽管编译通过了,但运行还是会出错。此处与存储无关。因此加不加static结果都是一样的。
如:
char a[]="hello";
char *b="hello";
a[2]='r';//允许对字符变量赋值
b[2]='d';//错误,字符串常量不可改变。
Case 4:
#include<stdio.h>#include<string.h>#include<stdlib.h>char* getMem(void){ char *p = "hello world";//程序可以运行 输出为"hello world" return p;}int main(){ char *s="fzz"; s=getMem(); printf("%s\n",s); return 0;}
这是因为如果定义一个字符数组,它只是一个字符数组变量,随着函数的调用结束,该变量所占有的内存也随之释放,因此返回的值是任意的;但是,如果用指针,它始终指向分配的内存,直到释放掉,因此返回值为"hello world"。
0 0
- 关于子函数返回字符串问题集锦
- 关于子函数返回字符串的问题解决办法
- 关于子函数返回指针的解决办法
- VTK 子函数返回SmartPointer的问题
- 关于子函数中用new的问题
- 子函数返回类型int
- 关于函数返回字符串常量的问题
- 关于Ajax返回字符串的问题
- 字符串问题集锦
- 关于子函数变量生命周期以及指针的一些问题
- 关于子函数调用
- c字符-字符串问题集锦
- 关于字符串比较函数strcmp返回值的问题
- 主函数调用子函数返回局部变量的问题及子函数的局部变量在函数结束后是否会销毁变量的内容
- 子函数
- malloc在子函数的问题
- 在C/C++中关于局部数组问题(子函数等)
- C++中使子函数返回多个值
- What is the difference between ++i and i++
- SVM十问十答
- Android 性能优化之使用MAT分析内存泄露问题
- Java正则表达式(二)
- C++ 4种类型类型转换
- 关于子函数返回字符串问题集锦
- GCD
- ACM 油田合并
- Android App 内存泄露之Handler
- Linux下printk输出
- 九度oj-1408-吃豆机器人
- 关于程序员话题的播客(podcast)
- UGUI Text Gradient
- 响应者链条