1

这是我的代码:

#include <stdio.h>

typedef struct node_struct {
    int data;
    struct node_struct *next;
} node;

void push(node *top, int data) {
    node *new_node = (node*) malloc(sizeof(node));
    new_node->data = data;
    new_node->next = top;
    top = new_node;
}

int main() {
    node *top = (node*) malloc(sizeof(node));
    top->data = 1;
    printf("Set data of top node to: %d\n", top->data);

    push(top, 2);
    printf("Pushed 2 to top, top->next->data = %d\n", top->next->data);
}

程序在最后一行(push(top, 2);)的第 3 行出现段错误,我认为就行了top = new_node;

我只是在学习 C(现在的指针)。

我做错什么了?

4

2 回答 2

5

这里的问题是您将指针top按值传递给元素,然后您尝试在函数内部设置指针,但它只是一个局部变量,对它的更改在函数外部是不可见的。

top而是通过引用传递指针,使用指向指针的指针:

void push(node **top, int data) {
    node *new_node = malloc(sizeof(node));
    new_node->data = data;
    new_node->next = *top;
    *top = new_node;
}

...

push(&top, 2);

另一种方法是从函数中返回新的顶部:

node *push(node *top, int data) {
    node *new_node = malloc(sizeof(node));
    new_node->data = data;
    new_node->next = top;
    return new_node;
}

...

top = push(top, 2);
于 2012-10-19T09:07:22.923 回答
1

指针按值传递给push。因此,您所做的更改top不会反映在main. 如果要更改,请top传递指针的地址:

#include <stdio.h>

typedef struct node_struct {
    int data;
    struct node_struct *next;
} node;

void push(node **top, int data) {
    node *new_node = (node*) malloc(sizeof(node));
    new_node->data = data;
    new_node->next = *top;
    *top = new_node;
}

int main() {
    node *top = (node*) malloc(sizeof(node));
    top->data = 1;
    printf("Set data of top node to: %d\n", top->data);

    push(&top, 2);
    printf("Pushed 2 to top, top->next->data = %d\n", top->next->data);
}

这是相关的C-FAQ

于 2012-10-19T09:08:17.853 回答