void add_book(struct node *head) { struct node *new = NULL; struct node *find = head; while (find->next != NULL) { find = find->next; } new = (struct node *)malloc(sizeof(struct node)); printf("请输入图书编号:\n"); scanf("%d", &new->data.number); printf("请输入图书名称:\n"); scanf("%s", new->data.name); printf("请输入图书作者:\n"); scanf("%s", new->data.writer); printf("请输入图书类别:\n"); scanf("%s", new->data.type); printf("请输入图书价格:\n"); scanf("%d", &new->data.price); new->next = NULL; find->next = new; printf("%s图书信息添加成功!\n", new->data.name); printf("\n"); }我的代码会报错
时间: 2024-03-21 17:42:06 浏览: 74
addbook代码
可以具体说明一下报错的内容吗?这样才能更好地帮你排除错误。不过从代码来看,有一个可能的问题是在使用`malloc`函数动态分配内存时没有进行错误检查,这可能导致内存分配失败而程序崩溃。你可以在`malloc`函数分配内存后,检查是否分配成功,如果分配失败,应该释放已经分配的内存并提醒用户重新操作。例如:
```c
new = (struct node *)malloc(sizeof(struct node));
if (new == NULL) {
printf("内存分配失败!\n");
return;
}
```
另外,你在输入图书名称、作者、类别时使用的是`scanf("%s", ...)`,这可能导致输入的字符串超出了结构体中定义的空间范围,从而导致内存越界错误。你可以使用`fgets`函数来输入字符串,并指定最大输入长度,例如:
```c
fgets(new->data.name, MAX_NAME_LEN, stdin);
fgets(new->data.writer, MAX_WRITER_LEN, stdin);
fgets(new->data.type, MAX_TYPE_LEN, stdin);
```
其中,`MAX_NAME_LEN`、`MAX_WRITER_LEN`、`MAX_TYPE_LEN`分别是预定义的最大字符串长度。
阅读全文