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)。

相关推荐
我不是加奈4 小时前
QMC5883L的驱动
c语言·驱动开发·单片机·嵌入式硬件
青小莫4 小时前
数据结构-C语言-链表OJ
c语言·数据结构·链表
CodeWithMe7 小时前
【C/C++】不同防止头文件重复包含的措施
c语言·开发语言·c++
whoarethenext8 小时前
使用 C/C++的OpenCV 实现模板匹配:从基础到优化
c语言·c++·opencv
合方圆~小文8 小时前
架空线路图像视频监测装置
c语言·c++·人工智能·嵌入式硬件·硬件工程·模拟退火算法
卖猪肉的痴汉9 小时前
4.2 C/C++开发环境:VSCode+CMake+MSYS2
c语言·c++·vscode
ღ 噫吁嚱9 小时前
【C/C++】实现固定地址函数调用
c语言·开发语言·c++
jinmo_C++10 小时前
第十四届蓝桥杯_省赛B组(C).冶炼金属
c语言·职场和发展·蓝桥杯
代码雕刻家13 小时前
7.4.分块查找
c语言·数据结构·算法
打倒焦虑14 小时前
C语言学习20250610
c语言