ハッシュ テーブルを反復処理し、キーと値を構造体の配列に格納しようとしています。私はsegfaultを取得し続けます。ポインターベースの構造体が原因だと思います。
構造体へのポインターと構造体の配列を使用する必要がある場合は、まだ混乱しています。
編集:動作するようになりました。以下の回答を参照してください。
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#include <glib.h>
typedef struct st {
char *key;
char *str;
int len;
} MyStruct;
int z = 0;
static void hash2struct (gpointer key, gpointer value, gpointer data) {
MyStruct **s = data;
gchar *k = (gchar *) key;
gchar *h = (gchar *) value;
s[z]->key = strdup(k);
s[z]->str =strdup(h);
z++;
}
int main(int argc, char *argv[]){
int i;
GHashTable *hash = g_hash_table_new(g_str_hash, g_str_equal);
g_hash_table_insert(hash, "Virginia", "Richmond");
g_hash_table_insert(hash, "Texas", "Austin");
g_hash_table_insert(hash, "Ohio", "Columbus");
MyStruct **s = malloc(sizeof(MyStruct) * 3);
for(i = 0; i < 3; i++) {
s[i] = malloc(sizeof(MyStruct));
}
g_hash_table_foreach(hash, hash2struct, s);
for(i = 0; i < 3; i++)
printf("%s %s\n", s[i]->str, s[i]->key);
for(i = 0; i < 3; i++) {
free(s[i]->str);
free(s[i]->key);
free(s[i]);
}
free(s);
g_hash_table_destroy(hash);
return 0;
}