微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Realloc 崩溃:cygwin_exception::open_stackdumpfile:将堆栈跟踪转储到 malloc.exe.stackdump

如何解决Realloc 崩溃:cygwin_exception::open_stackdumpfile:将堆栈跟踪转储到 malloc.exe.stackdump

我是动态内存分配的新手,我尝试编写一个简单的程序来使用第一个字符串的 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 分配时,您才可以将指针传递给 reallocmalloc

Proper usage of realloc()

你可以这样做

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。