所以我在这个函数中遇到了一个恼人的段错误问题,它应该会增加数组的大小。
void Node::pushArg(Argument arg)
{
Argument * newlist = new Argument[argc+1];
for (int i = 0; i < argc; i++)
newlist[i] = args[i];
newlist[argc] = arg;
delete[] args;
args = newlist;
argc++;
}
当我在使用gdb时运行它时,它告诉我我的段错误是由这一行引起的:
Argument * newlist = new Argument[argc+1];
我认为这可能是调整大小的问题(成员数与文字大小的字节数)所以我试过了:
Argument * newlist = new Argument[sizeof(Argument)*(argc+1)]
但这也会以完全相同的方式导致段错误。帮助
如果它有用:这是Node和Argument的定义
class Argument
{
public:
bool nested; // is the Argument a string, or a nested Node?
char * str_content; // string value
Node * nested_node; // Pointer to nested note
Argument(); // Null intializer
Argument(char *); // Create string node
Argument(Node *); // Create nested node
Argument(const Argument&); // Copy constructor
};
class Node
{
public:
char * head; // Head of list (function)
int argc; // # of arguments
Argument * args;
Node(); //intialize null
Node(char *); // intialize with head
void pushArg(Argument); // Add an argument to list
char * toString(); // the Node in String Format
};
答案 0 :(得分:1)
鉴于“argc”是一个成员值,segfault很可能是由于“this”是一个无效值,可能是NULL。您可以通过执行
来检查void Node::pushArg(Argument arg)
{
size_t numArgs = argc + 1;
然后在该行段错误时查看“this”的值。
您也应该使用“-Wall -Wextra -O0 -g”进行编译,以便从您的工具中获得最大的调试帮助。