C++在 while 循环后添加一行代码会导致错误
C++ adding one line of code after while loop causes an error
我已经尽力寻找一个解决我具体问题的答案,但不幸的是,我无法找到一个满足我需求的答案。
我正在用c ++为我编写的语言编写汇编程序。编写汇编程序涉及两个类,这两个类导致了非常难以调试的问题。我的调试技术已经转移到添加和删除输出流命令,例如
std::cout << "TEST";
最终会破坏或修复程序。我正在使用的IDE是Xcode。
我正在处理的两个类是 LinkedList 类和 SymbolTable 类,我将其用作符号解析的哈希表。
LinkedList.h
#include <iostream>
using namespace std;
struct Node{
string data;
int address;
Node* next = nullptr;
};
class LinkedList{
private:
Node* main_ptr;
int length;
public:
LinkedList();
void insertNode(string, int);
void deleteNode(string);
void displayList();
bool contains(string, int* = nullptr);
int getLength();
~LinkedList();
};
链接列表.cpp
#include "LinkedList.h"
LinkedList::LinkedList(){
main_ptr = nullptr;
length = 0;
}
void LinkedList::insertNode(string data, int address){
Node* newNode = new Node;
newNode->data = data;
newNode->address = address;
if (!main_ptr){
main_ptr = newNode;
} else {
newNode->next = main_ptr;
main_ptr = newNode;
}
length++;
}
void LinkedList::deleteNode(string data){
if (main_ptr){
int current_length = length;
if (main_ptr->data == data){
main_ptr = main_ptr->next;
return;
}
Node* q = main_ptr;
Node* p = q;
q = q->next;
while (q){
if (q->data == data){
p->next = q->next;
length--;
return;
}
p = q;
q = q->next;
}
if (current_length == length) cout << "Node was not found" << endl;
} else {
cout << "List is empty, cannot delete node!" << endl;
}
}
void LinkedList::displayList(){
if (!main_ptr){
cout << "List is empty!n";
} else {
Node* temp = main_ptr;
while (temp){
cout << temp->data;
temp = temp->next;
}
cout << endl;
}
}
bool LinkedList::contains(string data, int* address){
if (main_ptr == nullptr) return false;
else {
Node* temp = main_ptr;
while(temp != nullptr){
if (temp->data == data) {
address = &(temp->address);
return true;
}
temp = temp->next;
}
return false;
}
}
int LinkedList::getLength(){
return length;
}
LinkedList::~LinkedList(){
if (main_ptr){
Node* q = main_ptr;
Node* p = q;
while (q){
q = q->next;
delete p;
p = q;
}
}
}
符号表.h
#include "LinkedList.h"
#include <iostream>
class SymbolTable{
private:
LinkedList table[701];
public:
SymbolTable();
void addEntry(string, int);
void printTable();
bool contains(string, int*);
int convertName(string);
};
符号表.cpp
#include "SymbolTable.h"
SymbolTable::SymbolTable(){
}
void SymbolTable::addEntry(string name, int memory){
int address = convertName(name);
table[address].insertNode(name, memory);
}
void SymbolTable::printTable(){
for (int i = 0; i < 701; i++)
table[i].displayList();
}
bool SymbolTable::contains(string name, int* memory){
return table[convertName(name)].contains(name, memory);
}
int SymbolTable::convertName(string name){
int aggregate = 1;
const char* c_name = name.c_str();
for (int i = 0; i < name.length(); i++){
aggregate *= (int)c_name[i];
}
return aggregate%701;
}
现在我的实际问题来了。以下是主要功能:
#include "Parser.h"
#include "SymbolTable.h"
using namespace std;
int main(int argc, const char * argv[]) {
ifstream inputFile;
ofstream outputFile;
inputFile.open("/Users/Azaldin/Desktop/nand2tetris/projects/06/max/Max.asm");
outputFile.open("/Users/Azaldin/Desktop/nand2tetris/projects/06/max/Max.hack");
Parser a(inputFile);
SymbolTable s;
int commandType = -1;
string command;
int a_position = 16;
int currentLine = 0;
while (a.hasMoreCommands()){
a.advance();
commandType = a.commandType();
command = a.symbol();
if (commandType == 0){
if (!s.contains(command, nullptr)){
s.addEntry(command, a_position);
a_position++;
}
}
if (commandType == 2){
//cout << command << endl;
if (!s.contains(command, nullptr)){
s.addEntry(command, currentLine);
//cout << command << endl;
}
}
currentLine++;
}
string x; //<<<<<<<<<< ADDING THIS LINE BREAKS THE PROGRAM
cout << "Hi";
inputFile.close();
outputFile.close();
return 0;
}
在主函数中添加上面指向的行后,程序中断。 调试时,主线程出现以下问题:
线程 1:EXC_BAD_ACCESS(代码 = 1,地址 = 0x25fbfef80)
导致此问题的命令链:
从主功能
if (!s.contains(command, nullptr)){
return table[convertName(name)].contains(name, memory);
从符号表中.cpp"包含"函数if (temp->data == data) {
来自 LinkedList .cpp "contains" 函数
链命令的其余部分指向字符串类 == 运算符,然后指向左侧的 .size() 函数。
谢谢!
PaulMcKenzie的以下评论帮助解决了这个问题:
此外,聚合 *= (int)c_name[i]; -- 不能保证这一点 将是一个正数,因为字符可能是有符号的,因此 为您提供 -1 及以下的值。因此您的回报 合计%701;不会返回您期望的内容(数字>= 0)。
事实证明,传递给 SymbolTable 类中 convertName 函数的参数之一导致程序损坏了内存。我添加了一个 if 语句来解决问题。
- 读取最后一行代码算法 - c++ 时出现问题
- 需要将一行代码从C++ Qt翻译成PyQt
- 如何使代码打印文本文件中的第一行?
- 这段代码的最后一行在做什么?
- 在一行代码中理解 index++
- 单步执行代码时重复上一行
- 代码无尽写入文本文件的第一行
- 我可以在一行代码中将向量中与条件匹配的所有元素插入到集合中吗?
- a = !5 < a;在这一行代码中究竟做了什么?
- 无法理解代码的特定片段:这是一个函数,只是一行还是什么
- std::vector 从一行代码清空到下一行代码
- 我如何使一行代码可以选择,但在已经选择过一次后不重新选择
- 如何将具有多行代码的内联函数视为一行?
- C++在 while 循环后添加一行代码会导致错误
- 一行代码的Arduino运行时间
- 因为一行不相关的代码,速度相差那么大
- 在一行C 中,该代码后缀和前缀的输出的逻辑是什么
- 如何将.txt文件中的多维数组放入代码中,并一次打印一行
- 为什么此代码只能识别文本文件中的第一行?输入任何大于 1 的数字都会返回"Atomic Number Not Found"
- 分析执行C++代码的每一行所花费的确切时间