基本上我正在尝试构建一个 cstrings 的哈希结构,stringnode_ref *nodes
当哈希开始填满时,我可以将成员重新分配给一个更大的维度数组(malloc 一个新的,重新哈希现有的值,并删除旧的) .
字符串表.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;
}
字符串表.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;
. 有什么想法吗?