关于strcpy()

刚参加武汉烽火的笔试回来,其中一题要实现strcpy()函数,如果没猜错,应该是从林锐的《高质量C_C++编程》中借鉴,随手写了:
char * strcpy(char * desc,char * src)
{
    char *p;
    if(src == NULL) exit(0);
    if(desc == src) return desc;
    p = desc;
    while( *src == '/0')
        *desc++ = *src++;
    return p;
}

林锐的答案:
 

char *strcpy(char *strDest, const char *strSrc);

{

    assert((strDest!=NULL) && (strSrc !=NULL)); // 2

    char *address = strDest;                   // 2

    while( (*strDest++ = * strSrc++) != /0 )    // 2

       NULL ;

    return address ;                          // 2

}

恰好昨天在 CSDN上看到一个帖子讨论strcpy(); 
对其中相关的内容做了一点解释:
void test1()
{
int i;
char string[10];
char *str1="0123456789";
strcpy(string, str1); // 字符越界?
/*
错误:
strcpy(desc,src),
当src<=desc时, 如 char *str1="012345678",长度为10,
则string得到合理值,并且string[9]='/0';
当src>desc时,如  char *str1="0123456789",长度为11,
则string得到0-9的值,string[9]='9',
虽然可以运行,但string[9]后面的一个不属于string的字符
被恶意修改为‘/0',这不是我们想要的,也可能造成严重后果。
*/
printf("%s/n",string);
for(i=0;i<11;i ++)//故意循环11次,查看最后一个被无意修改的字节;
{
    printf("%c/t%d/n",string[i],string[i]);
}
printf("/n");
}

void test2()
{
int i;
char string[100], str1[10];
for(i=0; i<10;i++)
{
str1[i] ='a';
}
strcpy(string, str1);
/*
strcpy(desc,src)
会把src 视为string类型,拷贝时查找'/0'结束符,作为scr的结束,来付给desc;
所以,本程序虽然能够运行,但潜在的问题:
str1的所有10个元素被初始化为'a',但后续的字符是不可预料的,
直到”偶然“碰到了'/0',才停止识别str1;
如果string是个100个元素的大数组,则会发现str1后面的"随机元素"也被复制给了string
直到碰到'/0'
说"偶然",加引号,其实'/0'在未知内存中还是挺多的。呵呵
当然,如果desc是string[10]的话,也就会掐掉str1后面的东东,这就是表面上的运行正确;
*/
printf("%s/n",string);
for(i=0;i<100;i++)
{
    printf("%c/t%d/t%c/n",string[i],string[i],str1[i]); //对比来看;
}
printf("/n");
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值