双向链表中的访问冲突错误

时间:2014-10-26 13:13:53

标签: c doubly-linked-list

我在尝试将元素添加到双向链接列表时遇到此错误。我似乎无法找到错误。

struct Pacijent
{
    char ime[10];
    [...]
    Pacijent *prev;
    Pacijent *next;
};

struct Lista
{
    Pacijent *front;
    Pacijent *back;
};

void assign(Pacijent p1, Pacijent p2)
{
    memcpy(&p1.ime, &p2.ime, sizeof(p1.ime));
    [...]
}

这是导致错误的功能:

void insertBack(Pacijent p, Lista l)
{
    Pacijent *novi = (Pacijent*)malloc(sizeof(Pacijent));
    assign(*novi, p);
    if (l.back = NULL)
    {
        l.front = l.back = novi;
        novi->prev = NULL;
        novi->next = NULL;
    }
    else
    {
        novi->prev = l.back; //here is where I get the error
        l.back->next = novi;
        novi->next = NULL;
        l.back = novi;
    }
}

以及 main 函数的相应部分:

Lista *lista = (Lista*)malloc(sizeof(Lista));
    lista->back = lista->front = NULL;

    [...]
    Pacijent p1 = noviPacijent("Marko", "Markovic", "Milan", jmb1, 1.75, 70, 23);
    [...]

    insertBack(p1, *lista);

insertBack 函数对我来说似乎是正确的,我无法找到问题所在。 提前谢谢。

1 个答案:

答案 0 :(得分:1)

instertBack函数的第3行:if (l.back = NULL)
您可能需要将其更改为:if (l.back == NULL)