免费注册 查看新帖 |

Chinaunix

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

strcpy怎么这么神奇? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-11-18 16:24 |只看该作者 |倒序浏览
  1. #include <stdio.h>
  2. #include <string.h>

  3. char str[5];
  4. char pad[] = "xxxxxxxxxxxxxxxxxxxxxxxxxxxxx";
  5. int main()
  6. {
  7.         printf("str's address before strcpy: %x\n", str);
  8.         printf("pad's address before strcpy: %x\n", pad);
  9.        
  10.         strcpy(str,"1234567890abcdefghijklmnopqrstuvwxyz");
  11.        
  12.         printf("str's address after strcpy: %x\n", str);
  13.         printf("pad's address after strcpy: %x\n", pad);       
  14.        
  15.         printf("strlen(str): %d\n", strlen(str));
  16.         printf("str=%s\n, str);
  17.         return 0;
  18. }
复制代码


运行后竟然输出:
str's address before strcpy: 8049764
pad's address before strcpy: 8049720
str's address after strcpy: 8049764
pad's address after strcpy: 8049720
strlen(str): 36
str=1234567890abcdefghijklmnopqrstuvwxyz

是编译的时候把str的长度增加了吗?

论坛徽章:
0
2 [报告]
发表于 2008-11-18 16:26 |只看该作者
溢出了,这样做是错误的,你的程序没出错,是碰巧了。

论坛徽章:
0
3 [报告]
发表于 2008-11-18 16:39 |只看该作者
试运行了很多次(同时运行其他程序), 每次都没有任何错误及警告。
越界的地址能这样随便访问,是否太危险了?

论坛徽章:
0
4 [报告]
发表于 2008-11-18 16:45 |只看该作者
原帖由 sysno 于 2008-11-18 16:39 发表
试运行了很多次(同时运行其他程序), 每次都没有任何错误及警告。
越界的地址能这样随便访问,是否太危险了?

你把strcpy的源串写长点就core了
对于你自己的进程来说很危险,对于系统来说危险不大,不过如果你的程序以很高的权限运行,那就要危害系统了。

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
5 [报告]
发表于 2008-11-18 16:47 |只看该作者
缓冲区溢出。虽然这样使用没有报错,但是对系统来说是危险的。记住,你拥有多大空间,就写多少东西。不要越界

论坛徽章:
0
6 [报告]
发表于 2008-11-18 16:54 |只看该作者
char * __cdecl strcpy(char * dst, const char * src)
{
        char * cp = dst;

        while( *cp++ = *src++ )
                ;               /* Copy src over dst */

        return( dst );
}
不做任何安全检查,将第一个空字符之前的所有字符都拷贝进去,strlen也一样

论坛徽章:
1
天蝎座
日期:2013-08-25 10:27:22
7 [报告]
发表于 2008-11-18 16:58 |只看该作者
很多次都一样,应该是你后边的空间没影响到其他程序,或者没被其他的影响。

论坛徽章:
0
8 [报告]
发表于 2008-11-18 17:01 |只看该作者
内存坏了, 会发生很多神奇的现象

论坛徽章:
3
戌狗
日期:2014-09-10 17:07:162015年辞旧岁徽章
日期:2015-03-03 16:54:15wusuopu
日期:2016-06-17 17:43:45
9 [报告]
发表于 2008-11-18 17:11 |只看该作者
原帖由 sysno 于 2008-11-18 16:24 发表
#include
#include

char str[5];
char pad[] = "xxxxxxxxxxxxxxxxxxxxxxxxxxxxx";
int main()
{
        printf("str's address before strcpy: %x\n", str);
        printf("pad's address before strcpy: %x\n" ...

strlen()会找结束的'\0', 如果一直找不到,就该上百度了。

论坛徽章:
0
10 [报告]
发表于 2008-11-18 19:21 |只看该作者
还是使用strncpy吧.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP