在pinta上做题目:链式表操作集,编写程序后在VS2019平台下,程序发生运行崩溃。
经过一步步调试发现,程序在运行调试到free()函数这一步时发生了崩溃。
网络上查找其他人的代码,发现有些并没有使用free()函数,笔者注释掉free这一行时,在VS2019上直接运行,居然通过了检查,程序运行正确。在pinta上也能满分通过。
但是,根据所学,链表的节点删除时肯定必须释放其malloc申请的内存空间,不然会造成内存的泄露情况。
对于这种情况感觉非常难以理解,网上查找答案看到了一篇博客https://blog.csdn.net/linzi_1988。
文章说明了,这可能时malloc()申请内存的问题。
题目定义的结构体如下:
typedef struct LNode *PtrToLNode;
struct LNode {
ElementType Data;
PtrToLNode Next;
};
typedef PtrToLNode Position;
typedef PtrToLNode List;
而我在malloc申请内存时,
pnew = (Position)malloc(sizeof(Position));
这样确实是Position是一个指针,malloc申请内存得到了4个字节,神奇的是在插入新的节点时居然程序并没有报错,可以直接通过。而这样导致后面free其申请的空间时报错,将代码改成: