C 如何安全的free掉因为字符串拼接(strcat)引起的内存增长的内存

我的意思是这样的:
char * pName;
pName = malloc(strlen("Yums") + 1);//动态分配内存空间
memcpy(pName, "Yums", strlen("Yums") + 1);//对第一个字符串赋值

char sBobName[] = "Bob";
strcat(pName, sBobName);//进行字符串拼接,内存增长

free(pName);//在这就会出现内存泄露的问题,free不掉增长的空间,出现内存泄露
我知道一种方式是将第一个字符串开辟一个足够的空间,但是有没有更优雅的方式来处理这个问题呢,类似relloc函数一样可以在拼接时自动检查内存是否溢出,重新增加 空间。

你的代码的问题是pName太小了。

pName要有足够的控件容纳拼接后的字符串,这样就不会有泄漏,如果你破坏了pName,free会报错

这明显就是个bug,首先你pName也就5字节,然后你还strcat它,没奔溃就很幸运了,你还想free掉它。。。请先使用realloc调整大小,再strcat,再free,因为strcat不会动态分配空间,具体可以查看strcat的源码

strcat不会增加空间,pName的大小要足够,它只是把sBobName连在pName的'\0'的后面,是字符串的连接,不是数组的连接。

字符串的长度和字符数组的长度是两个概念,好比
char s[100];
s = "hello";
int n = strlen(s);
结果是5不是100.