问题描述
我是动态内存分配的新手,我尝试编写一个简单的程序来使用第一个字符串的 realloc 连接 2 个字符串(一个已初始化,一个从 stdin 读取)。但我收到此错误:
cygwin_exception::open_stackdumpfile:将堆栈跟踪转储到 malloc.exe.stackdump
代码在 realloc 处中断,我不知道为什么,您能帮忙吗?
输入:人活着。
预期输出:最心爱的人活着。
我曾尝试用数字替换 strlen,但无济于事。
这是我的代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
char *str = "The most beloved";
char str2[20];
scanf("%[^\n]%*c",str2);
//printf("%s %s\n",str,str2);
str = (char *)realloc(str,strlen(str) + strlen(str2));
strcat(str,str2);
printf("%s\n",str);
free(str);
}
解决方法
您正在分配一个指向 str
的指针,该指针不是使用 malloc
分配的。仅当使用 free
分配时,您才可以将指针传递给 realloc
或 malloc
。
你可以这样做
str = strdup("mystring");
此外,您还需要考虑最后的 \0
,因此应该是:
str = (char *)realloc(str,strlen(str) + strlen(str2)+1);
,
您声明了一个指向字符串文字的指针
char *str = "The most beloved";
字符串文字具有静态存储持续时间。因此它们可能不会被动态重新分配。
因此声明
str = (char *)realloc(str,strlen(str) + strlen(str2));
调用未定义的行为。
注意需要为结果字符串的终止零字符'\0'
预留内存。
您需要的是以下内容
char *result = ( char * )malloc( strlen(str) + strlen(str2) + 1 );
strcpy( result,str );
strcat( result,str2 );
puts( result );
free( result );
而且写起来会更安全
scanf("%19[^\n]",str2);