免费注册 查看新帖 |

Chinaunix

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

[C] strcmp判断不执行了,内存越界的问题? [复制链接]

论坛徽章:
2
IT运维版块每日发帖之星
日期:2016-02-10 06:20:01IT运维版块每日发帖之星
日期:2016-02-11 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-09-08 17:17 |只看该作者 |倒序浏览
本帖最后由 nxlinux 于 2012-09-08 18:29 编辑
  1. int main(void){
  2.         char str[1]={0};
  3.         char *str1="iloveyou";
  4.         printf("please a string:");
  5.         scanf("%s",str);
  6.         printf("%d\n",strlen(str));
  7.         if(!strcmp(str,str1)){
  8.                 printf("the same\n");
  9.         }else{
  10.                 printf("not the same\n");
  11.         }
  12. }
复制代码
这里 str我赋值iloveyou,肯定是越界了, 为什么 str的长度还是8,而且 下面的if判断语句没有执行?

论坛徽章:
5
技术图书徽章
日期:2013-11-07 13:21:58技术图书徽章
日期:2013-12-07 10:34:46技术图书徽章
日期:2014-04-23 08:50:31双鱼座
日期:2014-09-16 09:12:34亥猪
日期:2015-01-23 13:37:49
2 [报告]
发表于 2012-09-08 18:12 |只看该作者
楼主是来搞笑的吧。
----------------------------------------

论坛徽章:
2
IT运维版块每日发帖之星
日期:2016-02-10 06:20:01IT运维版块每日发帖之星
日期:2016-02-11 06:20:00
3 [报告]
发表于 2012-09-08 18:28 |只看该作者
你从哪里看出来的?

论坛徽章:
0
4 [报告]
发表于 2012-09-09 10:00 |只看该作者
str是在栈上分配的,LZ只申请了1个字节的空间,却向他写了9个字节,这里肯定越界了,超出的部分会覆盖原来栈里的东西(例如程序参数,程序返回地址等等),这一步是悄无声息的但却可以正常执行,所以会输出“the same”,但是由于原来栈里的东西已被覆盖,所以程序返回时会报错!
这是我的理解,欢迎指正!

论坛徽章:
0
5 [报告]
发表于 2012-09-09 12:38 |只看该作者
scanf输入流函数的读取操作如果读取到空格符就会停止读入,楼主所操作的读入连续的九个字符,scanf会分配连续空间给这个字符串,所以你后面的比较会是相等,而且读到的长度也是你输入的,但是这样的操作就会不安全。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP