出现异常:跟踪/断点陷阱-在VSCode中调试C++程序(使用动态内存分配)
Exception has occurred: Trace/breakpoint trap - Debugging a C++ program in VSCode (uses dynamic memory allocation)
我在这段代码中使用动态内存分配来删除节点。遇到delete someVar
时,我在VSCode调试器中遇到错误。
Exception has occurred
Trace/breakpoint trap
我不明白跟踪/断点陷阱的含义。你能解释一下吗?另外,请帮助我检测我的代码有什么问题?(顺便说一句,这是我为leetcode设置的解决方案,请忽略主列表的冗长设置(
#include <iostream>
#include <map>
using std::cin;
using std::cout;
using std::endl;
using std::map;
/**
* 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 ListNode {
public:
ListNode *next;
int val;
ListNode(int arg_val = 0, ListNode* arg_next = nullptr) {
val = arg_val;
next = arg_next;
}
};
class Solution {
public:
ListNode* removeNthFromEnd(ListNode* arg_head, int arg_n) {
ListNode* head = arg_head;
ListNode* traverser = arg_head;
ListNode* nexter = arg_head->next;
ListNode* previous = traverser;
int index = 0;
bool zero = false;
map<int, ListNode*> store;
signed int justcals[] = {arg_n - 0,
arg_n - 5,
arg_n - 10,
arg_n - 15,
arg_n - 20,
arg_n - 25,
arg_n - 30};
if (arg_n == 1) {
delete traverser;
traverser = nullptr;
return nexter;
}
while (traverser->next != nullptr) {
if (index % 5 == 0) store.insert({index, traverser});
traverser = traverser->next;
index = index + 1;
}
int min = 99999;
for (index = 0; index < 7; ++index) {
if (justcals[index] >= 0 && justcals[index] < min) {
if (justcals[index] == 0) {
zero = true;
min = justcals[index - 1] + (5 * (index - 1));
} else {
if (index == 0) min = 0;
else min = justcals[index] + (5 * index);
}
}
}
traverser = store.at(min);
index = min;
if (zero) {
traverser = head;
index = 0;
}
while (index != arg_n - 1) {
traverser = traverser->next;
index = index + 1;
}
traverser = traverser->next;
nexter = traverser->next;
delete traverser;
previous->next = nexter;
return head;
}
};
int main() {
Solution solver;
ListNode *lsptr;
ListNode node1(1);
ListNode node2(2);
ListNode node3(3);
ListNode node4(4);
ListNode node5(5);
ListNode node6(6);
ListNode node7(7);
lsptr = &node2; node1.next = lsptr;
lsptr = &node3; node2.next = lsptr;
lsptr = &node4; node3.next = lsptr;
lsptr = &node5; node4.next = lsptr;
lsptr = &node6; node5.next = lsptr;
lsptr = &node7; node6.next = lsptr;
lsptr = &node1;
cout << &*(solver.removeNthFromEnd(lsptr, 3)) << endl;
return 0;
}
delete
只能与使用new
创建的对象一起使用。
在堆栈上创建对象,并将lsptr
设置为指向这些对象。请注意,列表节点不是由new
创建的。然后删除lsptr
,这是无效的,因为它们不是由new
创建的。这会导致异常。程序不处理异常,因此它会通知操作系统程序已失败。这被称为操作系统中的陷阱。然后,操作系统通过以下方式处理故障:停止程序并跳到调试器(如果设置了(,也就是断点陷阱,或者终止程序。
要修复程序,请删除删除的内容。您不需要删除堆栈分配,只需要删除堆分配的对象(new
(。
相关文章:
- Mongodb c++驱动程序:如何查询元素的数组
- C++,系统无法执行指定的程序
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- 在VS代码中交叉编译Windows与Linux上的MinGW的SDL程序
- C++ Windows 驱动程序MSB3030无法复制该文件,因为它找不到
- 重载操作程序时出错>>用于类中的字符串 memebr
- 获取日期异步信号安全吗?如果在信号处理程序中使用,它会导致死锁吗
- 试图在visual studio上用C++创建一个桌面应用程序
- 模板元程序查找相似的连续类型名称
- FFmpeg:制作一个应用程序比直接使用ffmepg更好吗
- 如何通过cpp程序运行shell脚本
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- IPC使用多个管道和分支进程来运行Python程序
- 如何将c++程序的一些输出传递给shell,以便在shell中使用
- 使用C++程序合并排序没有得到正确的输出
- 基于boost的程序的静态链接——zlib问题
- 程序崩溃并显示"std::out_of_range"错误
- 在C应用程序中运行C++(带有STL)函数
- 使用mongocxx驱动程序时包含头文件问题
- 如何在c++程序中找到函数的地址