0

我有一个GList包含GSList. 此 GSlist 包含GString. 当我释放整个GList时,我得到分段错误。

现在检查以下代码。

GList *m_rows = NULL;
m_rows = mysql_multiple_rows(mysql, sql1->str);

g_list_foreach(m_rows, mysql_storage_load_settings, &data);
mysql_free_multiple_rows(m_rows); /// <----------------------- works just fine

m_rows = mysql_multiple_rows(mysql, sql2->str);

if(g_list_length(m_rows)>0){
    g_list_foreach(m_rows, mysql_storage_load_accounts, &data);
    mysql_free_multiple_rows(m_rows); /// <----------------------- Segmentation fault!
}else{
    fprintf(stderr, "\e[31m\tUser has no account!\e[0m");
}

所以m_rows只分配使用g_string_new(), g_slist_prepend()g_list_prepend()g_string_new()创建新GString的并添加到GSList. 然后将所有结果GSList添加到GList. 它发生在mysql_multiple_rows函数中。

他们正在free使用mysql_free_multiple_rows. 这个函数正好相反。

请参阅清理功能。

static void mysql_free_multiple_rows(GList *table){
    g_list_free_full(table, mysql_free_single_row);
}
static void mysql_free_single_row(gpointer data){
    g_slist_free_full(data, msyql_free_single_row_field); // data here is GSlist
}
static void msyql_free_single_row_field(gpointer data){
    g_string_free(data, TRUE); // data here is GString actually
}

谁能告诉我为什么我会收到这个错误?由于内存分配和解除分配顺序相同,我不知道为什么会发生这种情况。

  1. Valgrind 输出
  2. 源文件
4

1 回答 1

2

Looking at the code, you seem to be freeing password in mysql_storage_load_accounts(). However, I don't see any special handling for it, so my guess would be that it gets freed twice.

于 2012-07-18T17:17:54.927 回答