c语言中“在xxxx处有未经处理的异常”问题的分析与解决

本文介绍了在C语言编程中遇到的‘在xxxx处有未经处理的异常’问题,该问题源于使用malloc分配内存后未正确初始化指针。通过分析,发现未初始化的指针默认值可能导致程序访问保护数据区,从而引发崩溃。通过将指针初始化为NULL,成功解决了这一问题。
摘要由CSDN通过智能技术生成

在用局部变量写了链表之后,容易出现的问题是链表头的生命期结束。笔者为了避免这个问题用了一个malloc(),结果在运行的问题就出现了如题的问题。查了下资料大致知道怎么解决这种问题了。


笔者一开始的代码是这样的:

//CREATE THE HEAD OF A LINKED LIST
Word_list* linked_list_head = (Word_list*) malloc(sizeof(Word_list));
linked_list_head->next = 0;<span style="white-space:pre">		</span>//此处

Word_list* previous;
Word_list* current;
Word_list* pointer_learn;

//START TO READ THE DATA
FILE* filepointer = fopen(filename, "rb");

Word_list* object = (Word_list*) malloc(sizeof(Word_list));
fread(&object->word, 1, sizeof(object->word), filepointer);
fread(&object->explain, 1, sizeof(object->explain), filepointer);
fread(&object->example_sentence, 1, sizeof(object->example_sentence), filepointer);
fread(&object->count_total, 1, sizeof(object->count_total), filepointer);
fread(&object->count_correct, 1, sizeof(obje
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值