将双向链表写入二进制文件分段错误
fwriting a doubly linked list to a binary file segmentation faults
这是我的学生结构,其中包含我通过二进制读入的信息
typedef struct student_t {
//data in here
} student_t;
这就是我在 main
中声明它们的方式
double_linkedlist_t* listPtr;
student_t students;
node_t* node = NULLL;
我的文件是这样初始化的
FILE *file;
printf("What file would you like to select?\n");
fgets( filename, MAX_NAME_LENGTH, stdin );
strtok(filename, "\n");
fflush(stdin);
file = fopen(filename, "rb+wb");
这就是我的 fwrite 在我的 main 中的样子。我一直遇到分段错误,我看到的所有关于如何将双向链表写入二进制文件的示例都让你这样做了。所以我来这里是为了解释为什么或者可能对我所拥有的进行一些更改。我还在 main 中将双向链表声明为 listPtr,并将节点声明为 node。
这是我的初始化
node_t* Init_Node( student_t data )
{
node_t* node = (node_t*) malloc( sizeof( node_t ) );
node -> students = data;
node->nextPtr = NULL;
node->prevPtr = NULL;
return node;
}
这是我的节点结构以及 nodeinit 的原型
typedef struct node_t
{
student_t students;
struct node_t* nextPtr;
struct node_t* prevPtr;
} node_t;
//prototypes
node_t* Init_Node( student_t );
node = listPtr->headPtr; //segmentation faults here
while(node!=NULL)
{
fwrite(node, sizeof(student_t), 1, file);
node=node->nextPtr;
}
任何关于为什么会发生这种情况的帮助将不胜感激,我从来没有真正用双向链表写入二进制文件:/.
由于您没有给出更完整的代码,我只能猜测,但问题是:
double_linkedlist_t* listPtr;
看来这是在main
函数内部声明的局部变量,问题是函数内部的局部变量没有初始化。因此,通过声明而不是使指针实际指向某处,它将指向看似 随机 位置。
未初始化的局部(非静态)变量将具有 不确定的 值,取消引用指针而不使其指向任何有效位置将导致 undefined behavior 这是一个非常常见的崩溃原因。
有两种可能的解决方案:
分配内存并使指针指向它:
double_linkedlist_t* listPtr = malloc(sizeof *listPtr);
不要将其声明为指针开始,当需要指针时使用寻址运算符 &
获取一个:
double_linkedlist_t list;
list.headPtr = NULL;
list.tailPtr = NULL;
...
callSomeFunction(&list);
这是我的学生结构,其中包含我通过二进制读入的信息
typedef struct student_t {
//data in here
} student_t;
这就是我在 main
中声明它们的方式double_linkedlist_t* listPtr;
student_t students;
node_t* node = NULLL;
我的文件是这样初始化的
FILE *file;
printf("What file would you like to select?\n");
fgets( filename, MAX_NAME_LENGTH, stdin );
strtok(filename, "\n");
fflush(stdin);
file = fopen(filename, "rb+wb");
这就是我的 fwrite 在我的 main 中的样子。我一直遇到分段错误,我看到的所有关于如何将双向链表写入二进制文件的示例都让你这样做了。所以我来这里是为了解释为什么或者可能对我所拥有的进行一些更改。我还在 main 中将双向链表声明为 listPtr,并将节点声明为 node。
这是我的初始化
node_t* Init_Node( student_t data )
{
node_t* node = (node_t*) malloc( sizeof( node_t ) );
node -> students = data;
node->nextPtr = NULL;
node->prevPtr = NULL;
return node;
}
这是我的节点结构以及 nodeinit 的原型
typedef struct node_t
{
student_t students;
struct node_t* nextPtr;
struct node_t* prevPtr;
} node_t;
//prototypes
node_t* Init_Node( student_t );
node = listPtr->headPtr; //segmentation faults here
while(node!=NULL)
{
fwrite(node, sizeof(student_t), 1, file);
node=node->nextPtr;
}
任何关于为什么会发生这种情况的帮助将不胜感激,我从来没有真正用双向链表写入二进制文件:/.
由于您没有给出更完整的代码,我只能猜测,但问题是:
double_linkedlist_t* listPtr;
看来这是在main
函数内部声明的局部变量,问题是函数内部的局部变量没有初始化。因此,通过声明而不是使指针实际指向某处,它将指向看似 随机 位置。
未初始化的局部(非静态)变量将具有 不确定的 值,取消引用指针而不使其指向任何有效位置将导致 undefined behavior 这是一个非常常见的崩溃原因。
有两种可能的解决方案:
分配内存并使指针指向它:
double_linkedlist_t* listPtr = malloc(sizeof *listPtr);
不要将其声明为指针开始,当需要指针时使用寻址运算符
&
获取一个:double_linkedlist_t list; list.headPtr = NULL; list.tailPtr = NULL; ... callSomeFunction(&list);