基本的に、ハッシュがいっぱいになり始めたときに、メンバーをより大きな次元配列に再割り当てできるcstringのハッシュ構造を構築しようとしていますstringnode_ref *nodes
(新しいものをmallocし、既存の値を再ハッシュし、古いものを削除します) .
stringtable.c:
#include <stdio.h>
#include "stringtable.h"
struct stringnode{
hashcode_t key;
cstring value;
};
struct stringtable{
size_t dim;
size_t numEntries;
stringnode_ref *nodes;
};
stringtable_ref new_stringtable(){
size_t index = 0;
stringtable_ref sTable = malloc(sizeof(struct stringtable));
sTable->dim = 31;
sTable->numEntries;
sTable->nodes = malloc(31 * sizeof(struct stringnode));
for( index = 0; index < 31; index++ ){
sTable->nodes[index]->key = 0;
sTable->nodes[index]->value = NULL;
}
return sTable;
}
stringtable.h:
#ifndef __STRINGTABLE_H__
#define __STRINGTABLE_H__
#include <stdlib.h>
#include <inttypes.h>
typedef char *cstring;
typedef uint32_t hashcode_t;
typedef stringtable *stringtable_ref;
typedef stringnode *stringnode_ref;
stringtable_ref new_stringtable();
#endif // __STRINGTABLE_H__
oc.c:
#include <stdlib.h>
#include <stdio.h>
#include "stringtable.h"
int main( int argc, char **argv ){
stringtable_ref table = new_stringtable();
return EXIT_SUCCESS;
}
コンパイル:
gcc -g -O0 -Wall -Wextra -std=gnu99 -c stringtable.c
gcc -g -O0 -Wall -Wextra -std=gnu99 -c oc.c
gcc -g -O0 -Wall -Wextra -std=gnu99 -o oc stringtable.o oc.o
これはすべてエラーなしで正常にコンパイルされますがstringtable_ref table = new_stringtable();
、main() で宣言すると、プログラムはsTable->nodes[index]->key = 0;
. 何かご意見は?