1

所以我在这个函数中遇到了一个恼人的段错误问题,它应该会增加数组的大小。

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)]

但这也会以完全相同的方式导致段错误。帮助?

如果有帮助:这是节点和参数的定义

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
};
4

1 回答 1

1

鉴于“argc”是一个成员值,段错误可能是由“this”是一个无效值引起的,可能是 NULL。你可以通过这样做来检查这个

void Node::pushArg(Argument arg)
{
    size_t numArgs = argc + 1;

然后在该行段错误时查看“this”的值。

您可能还应该使用“-Wall -Wextra -O0 -g”进行编译,以从您的工具中获得最大的调试帮助。

于 2013-06-02T18:10:35.177 回答