g_cache_insert () вылетает с ошибкой нулевого указателя - PullRequest
0 голосов
/ 19 декабря 2010

Я написал тестовый пример в glib:

#undef G_DISABLE_ASSERT
#undef G_LOG_DOMAIN

#include <stdio.h>
#include <string.h>
#include "glib.h"

void function(gchar *key,gchar *value,gint *user_data)
{
 // give the count of the number of times the function was called
 (*user_data)++;
}

void cache_test()
{
 gchar *str1,*str2,*str3;
 GCache *cache = NULL;
 gint user_data = 0;

 g_assert((cache = g_cache_new( (GCacheNewFunc) g_ascii_strup,
     g_free, (GCacheDupFunc) g_strdup, g_free, g_str_hash, 
        g_str_hash, g_str_equal)) != NULL);
 g_print("\n g_assert g_cache_new");
    str1 = g_cache_insert(cache,"test");
    g_print("\n str1 = g_cache_insert(cache,test)");
    g_assert(!strcmp("TEST",str1));
    g_print("\n g_assert(!strcmp(TEST,str1))");
 str2 = g_cache_insert(cache,"test");
 g_print("\n str2 = g_cache_insert(cache,test)");
 g_assert(!strcmp("TEST",str1));
 g_print("\n g_assert(!strcmp(TEST,str1))");
 str3 = g_cache_insert(cache,"glib");
 g_print("\n str3 = g_cache_insert(cache,glib)");
 g_assert(!strcmp("GLIB",str3));
 g_print("\n g_assert(!strcmp(GLIB,str3))");
 g_cache_key_foreach (cache,(GHFunc)function,&user_data);
 g_print("\n g_cache_key_foreach (cache,(GHFunc)function,&user_data)");
 //g_cache_key_foreach would call function twice and make user_data == 2
 g_assert(user_data == 2);

 g_cache_value_foreach (cache,(GHFunc)function,&user_data);
 g_print("\n g_cache_key_foreach (cache,(GHFunc)function,&user_data)");
 //g_cache_value_foreach would call function twice and make user_data == 4
 g_assert(user_data == 4);

 g_cache_remove(cache,str1);
 g_print("\n g_cache_remove(cache,str1)");
 g_cache_remove(cache,str2); 
 g_print("\n g_cache_remove(cache,str1)");
 g_cache_remove(cache,str3); 
 g_print("\n g_cache_remove(cache,str1)");
 g_cache_destroy(cache);
 g_print("\n g_cache_destroy(cache)");
}


int main (int   argc,
      char *argv[])
{
 cache_test();
 return 0;
}

Теперь мой тестовый пример вылетает при str1 = g_cache_insert (cache, "test"); из-за разыменования нулевого указателя. Любая помощь, где я мог пойти не так?


Редактировать

Я только что попробовал еще 1 быстрое исправление тестового кода, чтобы подтвердить ваше предложение (об ошибке в g_ascii_strup). Я использовал звонок

cache = g_cache_new((GCacheNewFunc) g_strdup, 
  g_free, (GCacheDupFunc)g_strdup, g_free, g_str_hash, 
  g_str_hash, g_str_equal); 

то есть вместо g_ascii_strup () я использовал g_strdup ... Я не видел сбоев. Я что-то здесь упускаю?

И исправлена ​​ли ошибка g_ascii_strup () в последних версиях glib? Могу ли я узнать номер ошибки, если вам известно об этом?

1 Ответ

1 голос
/ 20 декабря 2010

Я бы убрал приведение (GCacheNewFunc) и (GCacheDupFunc), потому что они нарушают безопасность типов, и в этом случае скрывают ошибку: g_ascii_strup принимает параметр длины, который, вероятно, будет мусором.Вместо этого создайте функцию с правильной подписью и вызовите g_ascii_strup внутри этой функции.Тогда вам не нужен актерский состав.

Я думаю, в этом проблема.Но если нет, то я бы получил отладочные символы на вашей GLib и получил обратную трассировку в gdb.

...