2. 两数相加 c++

2. 两数相加 - 力扣(LeetCode)

Line 82: Char 28: ================================================================= ==22==ERROR: AddressSanitizer: stack-use-after-return on address 0x7f7399c003a8 at pc 0x5651d0ef1e46 bp 0x7ffce5baa990 sp 0x7ffce5baa988 READ of size 8 at 0x7f7399c003a8 thread T0 #0 0x5651d0ef1e45 in ListNodeUtils::hasCycle(ListNode*) (solution+0x1aae45) #1 0x5651d0ee4d15 in void Serializer::serialize<ListNode>(ListNode* const&, std::__cxx11::basic_string<char, std::char_traits<char>, std::allocator<char>>&) (solution+0x19dd15)

这个 AddressSanitizer (ASan) 错误

复制代码
ERROR: AddressSanitizer: stack-use-after-return
...
READ of size 8 at 0x7f7399c003a8
...
This frame has 2 object(s):
    [32, 48) 'node' (line 29) <== Memory access at offset 40 is inside this variable

说明你的程序 返回了一个指向栈上局部变量的指针 ,并在函数返回后使用了它 ------ 这是典型的 "栈对象使用后返回"(stack-use-after-return) 错误。

根本原因

你在某个函数(如 addTwoNumbers)中写了类似这样的代码:

cpp 复制代码
ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
    ListNode node(0);      // ← 栈上局部对象
    ListNode* head = &node; // ← 取栈对象地址
    // ... 操作 head ...
    return head;           // ❌ 返回栈对象地址!
}

ListNode* func() {
    ListNode dummy;        // 栈上节点
    ListNode* cur = &dummy;
    // 构建链表,cur 指向 dummy
    return dummy.next;     // 如果 dummy.next 指向其他栈对象,也可能出错
}

⚠️ 一旦函数返回,nodedummy 就被销毁,其内存不再有效。

但你返回了它的地址(或其成员的地址),后续使用(如 hasCycle 访问 next)就会读取已释放的栈内存 → 未定义行为(UB)

AddressSanitizer 检测到这一点,并报 stack-use-after-return

正确做法:在堆上分配节点

链表节点必须在 堆(heap) 上创建,才能在函数返回后继续使用:

cpp 复制代码
ListNode* addTwoNumbers(ListNode* l1, ListNode* l2) {
    ListNode* head = new ListNode(0);
    ListNode* cur = head;
    // ... 
    return head->next; // head 是堆对象,head->next 也是堆对象
}

题解

cpp 复制代码
/**
 * 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* addTwoNumbers(ListNode* l1, ListNode* l2) {
        ListNode* phead = new ListNode();
        ListNode* p = phead;
        int inval = 0;
        while(l1 && l2){
            int x = l1->val+l2->val+ inval;
            inval = x/10;
            x = x%10;
            p->next = new ListNode(x);
            p=p->next;
            l1 = l1->next;
            l2=l2->next;
        }
        while(l1){
            int x = l1->val+ inval;
            inval = x/10;
            x = x%10;
            ListNode node(x);
            p->next = new ListNode(x);
            p=p->next;
            l1 = l1->next;
           
        }
        while(l2){
            int x = l2->val+ inval;
            inval = x/10;
            x = x%10;
            ListNode node(x);
            p->next = new ListNode(x);
            p=p->next;
            l2=l2->next;
        }
        if(inval){
            p->next = new ListNode(inval);
        }
        return phead->next;
    }
};
相关推荐
天天进步20151 小时前
Motia性能进阶与未来:从现有源码推测 Rust 重构之路
开发语言·重构·rust
星空下的月光影子1 小时前
易语言开发从入门到精通:补充篇·办公+桌面自动化深度实战·Word/Excel/PDF联合处理·模拟键鼠·消息推送·定时任务调度
开发语言
Z9fish1 小时前
sse哈工大C语言编程练习22
c语言·开发语言·算法
小二·1 小时前
Go 语言系统编程与云原生开发实战(第12篇)云原生部署实战:Helm Chart × GitOps × 多环境管理(生产级落地)
开发语言·云原生·golang
小二·1 小时前
Go 语言系统编程与云原生开发实战(第13篇)工程效能实战:Monorepo × 依赖治理 × 构建加速(10万行代码实测)
开发语言·云原生·golang
暴躁小师兄数据学院2 小时前
【WEB3.0零基础转行笔记】Golang编程篇-第4讲:Go语言中的流程控制
开发语言·后端·golang·web3·区块链
j445566112 小时前
C++中的备忘录模式
开发语言·c++·算法
代码无bug抓狂人2 小时前
C语言之产值调整(蓝桥杯省B)
c语言·开发语言·蓝桥杯
近津薪荼2 小时前
dfs专题——二叉树的深搜3(二叉树剪枝)
c++·学习·算法·深度优先