背景:
有了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

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

被折叠的 条评论
为什么被折叠?



