2 yums467 yums467 于 2014.12.16 09:51 提问

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函数一样可以在拼接时自动检查内存是否溢出,重新增加 空间。

5个回答

devmiao
devmiao   Ds   Rxr 2014.12.16 10:03
已采纳

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

devmiao
devmiao   Ds   Rxr 2014.12.16 10:02

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

yums467
yums467 我知道出错原因是因为第一个字符串太小,导致内存溢出,在free的时候不能释放掉增长的内存空间,有没有一种方式可以释放点这个增长的空间呢?
接近 3 年之前 回复
devmiao
devmiao   Ds   Rxr 2014.12.16 10:07

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

bdmh
bdmh   Ds   Rxr 2014.12.16 10:00

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

zhutoubenben
zhutoubenben   2014.12.16 10:02

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

Csdn user default icon
上传中...
上传图片
插入图片