免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3250 | 回复: 5
打印 上一主题 下一主题

[C] malloc用strlen()的返回值分配内存的问题 [复制链接]

论坛徽章:
1
数据库技术版块每日发帖之星
日期:2016-07-07 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2016-05-30 23:21 |只看该作者 |倒序浏览
下面的代码能正常编译:
int main(void){
  char* a="0123456789";
  int i=strlen(a);
  printf("%s=%d\n",a,i);
  char* b=(char*)malloc(10*sizeof(char));
  strcpy(b,a);
  int j=strlen(b);
  printf("%s=%d\n",b,j);
}
结果是:
:~/$ ./test
0123456789=10
0123456789=10

但问题是,用strlen()得到的字符串上度是不包含‘\0’的,而strcpy会把'\0'加到字符串后面。
那为什么strcpy(b,a)不会内存溢出?

论坛徽章:
0
2 [报告]
发表于 2016-05-31 07:33 |只看该作者
小程序, a 字符串后面的 '\0' 确实保存在 b 缓冲区不可以控制位置,不过该位置并没有其它变量访问,并且你的程序立即退出了,这时操作系统并不会报 内存溢出的。

论坛徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16赛季CBA联赛之青岛
日期:2016-07-05 12:36:0515-16赛季CBA联赛之广东
日期:2016-06-29 11:45:542015亚冠之全北现代
日期:2015-07-22 08:09:472015年辞旧岁徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39狮子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技术图书徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
3 [报告]
发表于 2016-05-31 08:10 |只看该作者
那为什么strcpy(b,a)不会内存溢出?

溢出了呀,但溢出属于未定义行为,未定义行为就是一切都有可能

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
4 [报告]
发表于 2016-05-31 08:35 |只看该作者
补充一点,malloc的内存一般是8、16等字节对齐的,你10个字节就不会暴露问题了。

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
5 [报告]
发表于 2016-05-31 08:44 |只看该作者
错误的使用方式未必会带来错误的结果

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
6 [报告]
发表于 2016-06-01 23:08 |只看该作者
老陈73 发表于 2016-05-30 23:21
下面的代码能正常编译:
int main(void){
  char* a="0123456789";

这个,有个strdup,你man strdup看看。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP