strcat

strcat函数在C语言中存在安全隐患,可能导致内存溢出和系统崩溃。strcat_s提供了一种安全的实现,通过指定目标字符串的长度防止溢出。然而,由于指针按值传递的特性,直接使用str1 = strcat(str1,str2)可以避免地址问题。在使用strcat时需要注意检查输入是否为NULL以及是否需要重新分配空间。" 119911643,5658945,缓存异常处理:解决数据不一致的策略,"['数据一致性', '缓存管理', '并发控制', '数据库操作']
摘要由CSDN通过智能技术生成

背景:

有了String类之后,重载了operator +操作符,字符串的相加已经变得异常容易了。但是,strcat还是会时常出现在我们的眼前。

看了一些资料,总结了一下。

C的strcat:

C的strcat是最初的strcat,也是不安全的strcat。(当然,不安全的不止是strcat,和char*相关的很多比如strcpy等也都是不安全的)

它的源代码如下:

char * __cdecl strcat(char * dst, const char * src)
{
	char * cp = dst;          //保存dst指针
	while (*cp)
		cp++;                 //查找dst字符串的末尾
	while (*cp++ = *src++); //拷贝src字符串到dst后面
	return(dst);            //返回dst字符串指针
}

更直观一点的写法如下:

char *strcat(char *dst, const char *src)
{
	if ((dst == NULL) || (src == NULL))//增加了判断是否为NULL
		return dst; // or throw error
	char
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值