内容简介:有四种方式: 1。使用堆空间,返回申请的堆地址,注意释放 2。函数参数传递指针,返回该指针 3。返回函数内定义的静态变量(共享) 4。返回全局变量
有四种方式:
1。使用堆空间,返回申请的堆地址,注意释放
2。函数参数传递指针,返回该指针
3。返回函数内定义的静态变量(共享)
4。返回全局变量
******************以下摘自csdn******************************
其实就是要返回一个有效的指针,尾部变量退出后就无效了。
使用分配的内存,地址是有效
1 2 3 4 5 6 7 |
char *fun() { char* s = (char*)calloc(100, sizeof(char*) ); if (s) strcpy ( s , "abc " ); return s; } |
但这种方式需要注意,必须由使用将将返回的地址free掉
将地址由入参传入
1 2 3 4 5 6 |
char* fun(char*s) { if (s) strcpy(s, "abc "); return s; } |
这种方式调用都要注意给s分配的大小是足够。
可以这样:
1 2 3 4 5 6 7 8 9 |
char* fun(char*s, int len) { if (s) { strncpy(s, "abc ", len-1); s[len-1] = 0; } return s; } |
或才使用局部静态变量
1 2 3 4 5 6 |
char* fun() { static char s[100]; strcpy(s, "abc "); return s; } |
这种方式需要注意,不要修改返回的这个字符串,由于是共享地址,对它的修改会反应到每个调用者的。可以这样:
1 2 3 4 5 6 |
const char* fun() { static char s[100]; strcpy(s, "abc "); return s; } |
还有一种是使用全局变量
1 2 3 4 5 6 |
char g_s[100]; char* fun() { strcpy(g_s, "abc "); return s; } |
同样的,也要注意这个变量可存储的最大空间。
原文出处: turkeyzhou
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- SQL SERVER 2012新增函数之字符串函数FORMAT详解
- SQL SERVER2012中新增函数之字符串函数CONCAT详解
- jstl 字符串处理函数
- MySQL常用字符串函数
- PHP 常用字符串相关函数
- 009.Python字符串相关函数
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Web前端黑客技术揭秘
钟晨鸣、徐少培 / 电子工业出版社 / 2013-1 / 59.00元
Web前端的黑客攻防技术是一门非常新颖且有趣的黑客技术,主要包含Web前端安全的跨站脚本(XSS)、跨站请求伪造(CSRF)、界面操作劫持这三大类,涉及的知识点涵盖信任与信任关系、Cookie安全、Flash安全、DOM渲染、字符集、跨域、原生态攻击、高级钓鱼、蠕虫思想等,这些都是研究前端安全的人必备的知识点。本书作者深入剖析了许多经典的攻防技巧,并给出了许多独到的安全见解。 本书适合前端工......一起来看看 《Web前端黑客技术揭秘》 这本书的介绍吧!