为什么该程序会产生细分错误?

时间:2018-11-14 16:09:51

标签: c++ linked-list segmentation-fault

我目前正试图解决编码挑战,以学习我的入门c ++课程,而我只是想了解我遇到的分段错误。

我正在编写一个给定的函数,以在链表的末尾插入节点。这个想法是,给定整数输入,第一个输入将被视为列表末尾的一部分,因为它的指针成员变量将为nullptr。然后,必须附加所有其他输入,以便它们的插入发生在该空节点之前。

这是函数的第一部分:

SinglyLinkedListNode* insertNodeAtTail(SinglyLinkedListNode* head, int data) {


if(head == nullptr) //if the list is empty
{
    head -> next = new SinglyLinkedListNode(data);
    return head;
}

return head;

} 

但是函数的这一部分给了我一个分段错误错误:

head -> next = new SinglyLinkedListNode(data);

这些是类声明:

#include <bits/stdc++.h>

using namespace std;

class SinglyLinkedListNode {
 public:
    int data;
    SinglyLinkedListNode *next;

    SinglyLinkedListNode(int node_data) {
        this->data = node_data;
        this->next = nullptr;
    }
     };

class SinglyLinkedList {
public:
    SinglyLinkedListNode *head;

    SinglyLinkedList() {
        this->head = nullptr;
    }

 };

和主要:

int main()
{
ofstream fout(getenv("OUTPUT_PATH"));

SinglyLinkedList* llist = new SinglyLinkedList();

int llist_count;
cin >> llist_count;
cin.ignore(numeric_limits<streamsize>::max(), '\n');

for (int i = 0; i < llist_count; i++) {
    int llist_item;
    cin >> llist_item;
    cin.ignore(numeric_limits<streamsize>::max(), '\n');

    SinglyLinkedListNode* llist_head =
    insertNodeAtTail(llist->head, llist_item);
    llist->head = llist_head;
}

print_singly_linked_list(llist->head, "\n", fout);
fout << "\n";

free_singly_linked_list(llist->head);

fout.close();

return 0;
 }

我当时在想:

 head -> next = new SinglyLinkedListNode(data);

将使用data参数作为成员数据创建一个新节点,然后当前的头节点将指向该列表。

我想知道为什么发生此分段错误。另外,我不能更改任何类声明或构造函数,因为这是在挑战中给出的方式。

GDB跟踪:

Reading symbols from solution...done.
[New LWP 22279]
Core was generated by `solution'.
Program terminated with signal SIGSEGV, Segmentation fault.
#0  0x0000000000400eea in insertNodeAtTail (head=<optimized out>, 
data=<optimized out>) at solution.cc:62
62          head -> next = new SinglyLinkedListNode(data);
#0  0x0000000000400eea in insertNodeAtTail (head=<optimized out>, 
data=<optimized out>) at solution.cc:62
#1  0x0000000000400c2e in main () at solution.cc:88

2 个答案:

答案 0 :(得分:5)

因为取消引用空指针(head IS 空)为undefined behavior,其结果可能是分段错误:

if(head == nullptr) //if the list is empty
{
    head -> next = new SinglyLinkedListNode(data);

答案 1 :(得分:0)

Head为空。 您无法访问空对象的“下一个”字段。

if(head == nullptr) //if the list is empty
{
    head = new SinglyLinkedListNode(data);
    return head;
}
return insertNodeAtTail(head->next, data)