Zongshichao 发表于 2021-12-7 10:09:28

请问第一个代码会发生value 3221225477

第一个代码:
void getinput(struct Book* book)
{
        book = (struct Book*)malloc(sizeof(struct Book));
        if (book == NULL)
        {
                printf("内存分配失败!\n");
                exit(1);
        }
        printf("请输入书名;\n");
        scanf("%s",book->title);
        printf("请输入作者;\n");
        scanf("%s",book->author);
       
}


void addbook(struct Book**head)
{
        struct Book* temp;
        struct Book* book;
       
       
        getinput(book);
        if(*head == NULL)
        {
                *head = book;
                book->next = NULL;
        }
        else
        {
               
                temp = *head;   
                *head = book;
                book->next = temp;
        }
}


第二个代码:
void getinput(struct Book* book)
{
       
        if (book == NULL)
        {
                printf("内存分配失败!\n");
                exit(1);
        }
        printf("请输入书名;\n");
        scanf("%s",book->title);
        printf("请输入作者;\n");
        scanf("%s",book->author);
       
}


void addbook(struct Book**head)
{
        struct Book* temp;
        struct Book* book;
        book = (struct Book*)malloc(sizeof(struct Book));
       
        getinput(book);
        if(*head == NULL)
        {
                *head = book;
                book->next = NULL;
        }
        else
        {
               
                temp = *head;
                *head = book;
                book->next = temp;
        }
}


代码是小甲鱼上课的例子,区别在于book = (struct Book*)malloc(sizeof(struct Book));这句话在哪个函数里面,但是一个能跑一个不能跑是为什么呀{:5_90:}

jackz007 发表于 2021-12-7 11:31:43

本帖最后由 jackz007 于 2021-12-7 11:37 编辑

      两个代码除了
      book = (struct Book*)malloc(sizeof(struct Book));
      位置不同外,剩下的完全一样,代码的功能、逻辑一模一样,不可能一个可以运行,另一个不能。
      相较而言,代码 1 的逻辑更加合理,因为,判断 malloc() 内存分配的操作是否成功本来就应该和函数调用整合在一起,代码 1 做到了,代码 2 没有做到,代码 2 把内存分配结果的判断和错误信息输出放在了另外一个函数里,这样操作虽然勉强可以,但是,其逻辑完美程度远不及代码 1。
页: [1]
查看完整版本: 请问第一个代码会发生value 3221225477