繁体   English   中英

传递链表并获取它的值

[英]passing linkedlist and get value of it

对于令人困惑的代码,我感到非常抱歉,所以我试图改变整个问题,使它更简单:

所以基本上,我有一个预定义的结构,我从 header 文件中获得,我把它放在一个主文件中。 我需要创建一个 function,它可以在我自己的 function 中获取 value1->identity 的值。

我不应该将 value1 作为参数传递,因为我可以从用户结构访问 value1。 但是我如何在 int funct(user *user) 中执行此操作,所以当我在 int funct(user *user) 中打印 value1->identity 时,它不会返回垃圾值。

谢谢

#include <stdio.h>
#include <string.h>

typedef struct {
    int identity;
} value;

typedef struct list1_struct {
    value value1;
    struct list1_struct *next, *prev;
} list_t_slot;

typedef struct {
    list_t_slot *head, *tail;
} list_t;

typedef struct {
    int number;
    list_t value1s;
} value2;

typedef struct list2 {
    value2 conn;
    struct list2 *next, *prev;
} list_t_slot2;

typedef struct {
    list_t_slot2 *head, *tail;
} list_t2;

typedef struct {
    int power;
    list_t2 connections;
} user;

int funct(user *user) {

    return 1;
}

int main() {
    user user;
    memset(&user, 0, sizeof(user));

    list_t_slot2 chron_slot;
    memset(&chron_slot, 0, sizeof(chron_slot));
    value2 *conn = &chron_slot.conn;

    list_t_slot value1_slot;
    memset(&value1_slot, 0, sizeof(value1_slot));
    value *value1 = &value1_slot.value1;

    user.power = 1;
    value1->identity = 1;

    printf("value of identity is %d\n", value1->identity);

    funct(&user);

    return 1;
}

您是否注意到直到funct结束才使用user变量?

您正在使用未初始化的指针。 这就是为什么你会得到不同的(同样是垃圾)结果。 你必须先解决这个问题。

首先:

chron_apn_con_list_t_slot *chron_slot;
chron_apn_con_t *conn = &chron_slot->conn;

这没有任何意义。 没有chron_slot object 可以使用。 您要么需要使用malloc分配一个,要么使用堆栈 object 通过在声明chron_slot时省略指针表示法。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM