strcat函数

函数理解记忆:str表示是<string.g>中的函数,cat表示附加。意思是将一个字符串的内容附加到另一个字符串的末尾。

注意要点:既然要附加,附加的字符串和被附加的字符串都要有'\0'。否则不知道附加多少,不知附加在哪。

函数的传入值和返回值: char* strcat(char*brr,const char*arr),其中brr是被附加者,arr是附加者。返回附加的结果的指针。

函数的自我实现

char* my_strcat(char* brr, char* arr) {

while (*(brr++) != '\0') { ; } //找到brr的末尾

--brr; //找到'\0'后brr还会加一次,所以要将地址减一

while ((*(brr++) = *(arr++) )!= '\0') { ; } //这里先赋值再判断如果满足地址加加,不满足退出循环

return brr;

}

但是这个代码看着不好看,我们用for循环重新搞一下

char* my_strcat(char* brr, char* arr) {

for (; *brr != '\0'; ++brr); //也满足先判断后增,但是是前增,不会有判断是'\0'后又加一次

for (*brr = *arr; *arr != '\0'; *(++brr)=*(++arr));//先赋值一次,如果arr开始就是'\0'也没问题,不改变brr。然后判断是否满足循环条件,然后继续地址加加的形式赋值。这样可以防止越界

return brr;

}

但是就算是库里面的strcat也有很大的问题,如果我们不把brr的空间搞足就会报错。所以我自己改进了一下。

char* my_strcat(char* brr, char* arr, int capacity_brr) {//因为这里不能用sizeof来求空间,只能自己输入

int lenbrr = (int)strlen(brr);

int lenarr = (int)strlen(arr);

char* newbrr = brr,*pbrr=NULL;

if (capacity_brr < (lenbrr + lenarr)) {

pbrr = (char*)malloc(sizeof(char) * (lenbrr + lenarr));//如果空间不足就创建一个更大的,用不了realloc,因为两个字符串不是malloc或者realloc创建出来的。

if (pbrr == NULL)return NULL;//判断创建好了没

strcpy(pbrr, brr);//把brr的东西拷贝到新的内存中

newbrr = pbrr;

}

int k = 0;

for (; *newbrr != '\0'; ++newbrr)++k;

for (*newbrr = *arr; *arr != '\0'; *(++newbrr)=*(++arr))++k;//同样的操作

return newbrr - k;

}

但是我觉得依然有点问题,这里自己多加了传入值。这里也不能用realloc导致brr空间会浪费掉(不能free)。

相关推荐
444A4E2 小时前
深入理解Linux进程管理:从创建到替换的完整指南
linux·c语言·操作系统
敲上瘾2 小时前
Linux I/O 多路复用实战:Select/Poll 编程指南
linux·服务器·c语言·c++·select·tcp·poll
海天胜景2 小时前
编译器错误消息: CS0016: 未能写入输出文件“c:\Windows\Microsoft.NET... 拒绝访问
c语言·windows
草莓熊Lotso4 小时前
【C语言强化训练16天】--从基础到进阶的蜕变之旅:Day8
c语言·开发语言·c++·刷题·强化训练
pusue_the_sun13 小时前
数据结构:二叉树oj练习
c语言·数据结构·算法·二叉树
曙曙学编程16 小时前
stm32——GPIO
c语言·c++·stm32·单片机·嵌入式硬件
XH华1 天前
C语言第九章字符函数和字符串函数
c语言·开发语言
♞沉寂1 天前
信号以及共享内存
linux·c语言·开发语言
SunnyKriSmile1 天前
【冒泡排序】
c语言·算法·排序算法
_poplar_1 天前
08.5【C++ 初阶】实现一个相对完整的日期类--附带源码
c语言·开发语言·数据结构·c++·vscode·算法·vim