星号:双重自由或腐败(fasttop)

asterisk: double free or corruption (fasttop)

我要用ast_malloc和ast_realloc拼接一个长字符串functions.When我加载这个模块会出现段fault.What的问题?非常感谢! Asterisk 的输出是这样的:

*** glibc detected *** asterisk: double free or corruption (fasttop):     0x00007fd56c000b20 ***
======= Backtrace: =========
/lib64/libc.so.6[0x33b9675f3e]
/lib64/libc.so.6[0x33b9678dd0]
/lib64/libc.so.6[0x33b967bd60]
/lib64/libc.so.6(realloc+0x158)[0x33b967c058]
/usr/lib64/asterisk/modules/app_test2.so(func+0x25)[0x7fd5330d19c5]
/usr/lib64/asterisk/modules/app_test2.so(+0xa92)[0x7fd5330d1a92]
asterisk[0x5175d5]
asterisk(ast_load_resource+0x34)[0x51a924]
asterisk[0x4c0f80]
asterisk(ast_cli_command_full+0x162)[0x4c3ad2]
asterisk(ast_cli_command_multiple_full+0x7c)[0x4c3cfc]
asterisk[0x450b9a]
asterisk[0x5c41cb]
/lib64/libpthread.so.0[0x33b9a07aa1]
/lib64/libc.so.6(clone+0x6d)[0x33b96e8aad]

以及如下所示的代码:

#include "asterisk.h"
#include "asterisk/module.h"
#include "asterisk/strings.h"
#include "asterisk/json.h"
#include "asterisk/res_odbc.h"

ASTERISK_FILE_VERSION(__FILE__, "$Revision$")

#define AST_MODULE "app_test"

void func(char* test, const char* src)
{
    char* new_test = (char*)ast_realloc(test, strlen(test) + 32);

    if ( NULL == new_test ){
        ast_log(LOG_ERROR, "realloc error\n");
        return;
    }

    test = new_test;
    strcat(test, src);
}

static int load_module(void)
{

    int i;
    char* test;
    char* src = "MingYuan";
    test = (char*)ast_malloc(16);

    for (i = 0; i < 6; i++) {
        func(test, src);
    }

    ast_log(LOG_DEBUG, "\n++++\n%s\n*******\n", test);
    ast_free(test);

    return AST_MODULE_LOAD_SUCCESS;
}

static int unload_module(void)
{

    return 0;
}

AST_MODULE_INFO(
    ASTERISK_GPL_KEY, AST_MODFLAG_LOAD_ORDER, "APP_TEST",
    .load = load_module,
    .unload = unload_module
);
func 中的

strlen(test) 没有意义,因为您还没有将字符串复制到 test 中;这可能会导致不稳定的行为。我的建议是,在 test = (char*)ast_malloc(16); 之后你可能想要 strcpy(test, "");test[0] = '[=16=]';...

由于 C 中的 pass-by-value 语义,这些更改对 func 的调用者不可见:

test = new_test;
strcat(test, src);

调用者将在指针变量中的某处有一个旧的、无效的指针值,这肯定会在以后再次使用时导致更不稳定的行为...

我的建议是你开发函数让调用者分配内存;这不仅可以解决您的问题,还可以让您更灵活地分配如何您的内存分配,更频繁。