LeetCode “AddressSanitizer:heat-use-after-free on address“问题解决方法

heat-use-after-free : 访问堆上已经被释放的内存地址

现象:同样代码在LeetCode上报错,但是自己在IDE手动打印并不会报错

个人猜测,这个bug可能来源于LeetCode后台输出打印链表的代码逻辑问题。

问题描述

题目来自LeetCode的86.链表分隔
运行如下代码时,发生报错

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* partition(ListNode* head, int x) {
        cout << "dfddf" << endl;
        ListNode* head_s = new ListNode(-1), *p_s = head_s;
        ListNode* head_g = new ListNode(-1), *p_g = head_g;
        p_g = head_g;
        cout << "fdfdfdf" << endl;
        while (head != nullptr){
            if (head -> val < x){
                p_s -> next = head;
                p_s = p_s -> next;
            }
            else{
                p_g -> next = head;
                p_g = p_g -> next;
            }
            head = head -> next;
        }
        p_s -> next = head_g -> next;
        return head_s -> next;
    }
};

报错示例

问题解释

打印日志debug了半天也没知其然,于是上网搜了一圈,基本说的都是链表问题当中使用delete会在LeetCode平台上发生这个问题。还有一个直接说是指针指向了自己,也没给出个解决方法。

偶然在stackoverflow上看到了一个相似的问题

stackoverflow链接
解决回答

也就是说没有正确的结束链表,就像上面图那样链表末尾并没有结束而又连回来到了中间某个节点上,而我猜测LeetCode给一个链表头打印出链表的代码是打印完一个节点后就自动帮你把节点给释放掉了,而你链表末尾又指向了之前已被释放的节点。

解决方法

在链表结尾指向nullptr

p_g -> next = nullptr;

最近更新

  1. TCP协议是安全的吗?

    2024-02-15 14:04:02       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-15 14:04:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-15 14:04:02       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-15 14:04:02       20 阅读

热门阅读

  1. 12.13 校招 实习 内推 面经

    2024-02-15 14:04:02       35 阅读
  2. Spring Cloud Eureka:服务注册与发现

    2024-02-15 14:04:02       28 阅读
  3. 面对Copilot时代:机遇与挑战的解析

    2024-02-15 14:04:02       25 阅读
  4. 梯度提升树系列9——GBDT在多任务学习中的应用

    2024-02-15 14:04:02       29 阅读
  5. MySQL中常见的几种日志类型【重点】

    2024-02-15 14:04:02       38 阅读
  6. 102.二叉树的层序遍历

    2024-02-15 14:04:02       30 阅读
  7. 107.二叉树的层序遍历 II

    2024-02-15 14:04:02       35 阅读