[英]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.