0

有人可以帮我理解为什么当我尝试打印出 student_name 的值时,它只返回 null 吗?我在 C 中实现了一个基本的哈希表来存储学生的姓名、ID 和 2 个测试。其他一切都正确存储,无论我尝试什么,我都无法保存 student_name。我有两个结构,哈希表本身,然后记录我打算放入表中的元素。字符串永远不会超过 18 个字符。

int main(){
    char op[1];
    int stu_id[1];
    int exam1[1];
    int exam2[1];
    char * student_name = (char*)malloc(18*sizeof(char));

    struct hashtable * dictionary = malloc(sizeof(struct hashtable));
    dictionary->size = 13;
    dictionary->table = malloc(13*sizeof(struct record *));

    if(dictionary==NULL||dictionary->table==NULL){
        printf("Unable to allocate memory for the dictionary.\n");
        return;
    }

    int i;
    int s = 13;
    while(i<s){
        dictionary->table[i]=NULL;
        i++;
    }

    while(scanf("%s %d %d %d %s", op, stu_id, exam1, exam2, student_name) !=EOF){

        if(*op=='i'){
            printf("Intializing %s\n", *student_name);
            add_item(dictionary, stu_id[0], exam1[0], exam2[0], student_name);
    }
    free(dictionary);
    free(student_name);
    return 0;

}
4

2 回答 2

1

请记住,字符串始终必须包含特殊的终止符 ( '\0')。这意味着长度为 1 的字符串(如您的op数组)实际上是两个字符。

这意味着当您读入时op,您实际上是在超出数组范围进行写入,从而导致未定义的行为。您要么需要增加op(至少两个)的大小,要么将其声明为单个char(即不是数组)并使用'%c'格式代码读取单个字符。

另外,不要将整数变量声明为数组,而是&在调用时使用 address-of 运算符scanf

char op;
int stu_id;
int exam1;
int exam2;

/* ... */

scanf("%c %d %d %d %s", &op, &stu_id, &exam1, &exam2, student_name)

您也不应该检查scanfagainst的返回值,EOF以防输入格式不正确。将其与您要扫描的值的数量进行比较,在您的情况下为五个。

于 2013-09-16T05:57:48.530 回答
0

我想您正在为 add_item() 中的学生记录分配内存并将它们分配给字典-> 表。从您发布的代码中,您分配内存来保存指向结构学生记录的指针,而不是记录本身。

您需要在 main() 的末尾释放为“dictionary->table”分配的内存。

于 2013-09-16T06:18:12.863 回答