strcpy实现机制,数组越界-->memcpy,memmove

本文通过一道C++面试题探讨了strcpy使用不当可能导致的数组越界问题,以及memcpy在特定情况下的隐患。分析了strcpy的内部实现,指出在复制字符串时应确保末尾有''以防止越界。同时,提到了memcpy和memmove的区别,强调了在内存区域可能重叠时应使用memmove以保证正确复制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

先来看一个常见的C++面试题目:

void test()
{
 charstring[10],str1[10];
 int i;
 for(i=0; i<10; i++)
 {
  str1[i] ='a';
 }
 strcpy( string, str1 );
}

这个题目错误在于哪里?

答:数组越界,在对str[i] = 'a';循环赋值过程中最后没有'/0'标识符,导致在strcpy进行拷贝的时候越界,会导致程序崩溃,

看strcpy的内部实现:

char *  strcpy(char * dst, const char * src)
{
        char * cp = dst;

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

        return( dst );
}
看到没,是直接赋值!没有参数检测assert(dst != NULL);和assert(src != NULL));,也没有'\0'字符串结尾判断。

现在我们将程序改一下,如下:

char* strcpy_1(char* dest, const char* src)
{
	char * ret = dest;
	memmove(ret, src, strlen(src)+1);
	return
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值