原始计划的后续行动:Segmentation fault (core dumped) in C byte reader
我的程序应该是模仿(以原始方式),但目前无效。
我已经在这方面工作了相当长的时间,之前由于我用作first_node的未初始化节点,或者因为我之前使用的方式,我之前遇到了分段错误(核心转储) feof()而不是fread(...)!= 0.我已经实现了从昨晚开始提出问题的两个建议,但现在我更加不知所措。我不太确定这个错误意味着什么,更不用说为什么我会得到它。以下是我的源代码:
#include <stdio.h>
#include <stdlib.h>
struct node{
char ANSII;
struct node *next_node;
};
void clear_list(struct node *first_node);
void print(struct node *first_node);
int counter(struct node *first_node);
void append(char temp, struct node *first_node);
int main(int argc, char **argv){
FILE *f = NULL;
struct node header;
char temp;
if(argc != 2){ /* argv[0] = name of the program, argv[1] = file to open */
printf("usage: %s filename:", argv[0]);
}
f = fopen(argv[1], "rb");
if(f == 0){ /* check for successful read */
printf("Could not open file.\n");
}
while(!feof(f)){
fread(&temp, sizeof(1), 1, f);
if(temp >= 32 && temp <= 128){ /* If it falls between the bounds of printable characters. */
append(temp, &header); //Builds the string
}else{
if(counter(&header) > 3){
print(&header);
}
clear_list(&header);
}
}
return 0;
}
void clear_list(struct node *first_node){
struct node *conductor;
while(first_node != NULL){
conductor = first_node;
while(conductor->next_node != NULL){
conductor = conductor->next_node;
}
free(conductor);
}
}
void print(struct node *first_node){
struct node *conductor = first_node;
while(conductor != 0){
printf("%s", conductor->ANSII);
conductor = conductor->next_node;
}
printf("\n");
}
int counter(struct node *first_node){
struct node *conductor = first_node;
int counter = 0;
while(conductor != 0){
conductor = conductor->next_node;
counter++;
}
return counter;
}
void append(char temp, struct node *first_node){
struct node *conductor = first_node;
while(conductor->next_node != 0){
conductor = conductor->next_node;
}
conductor->next_node = malloc(sizeof(conductor->next_node));
if(conductor->next_node == 0){
printf("Memory allocation failed!");
return;
}
conductor = conductor->next_node;
conductor->ANSII = temp;
}
到目前为止,我尝试实现了这些答案,现在而不是分段错误,我遇到了以下运行时崩溃:
*** glibc detected *** ./mystrings: double free or corruption (fasttop): 0x0000000000601250 ***
======= Backtrace: =========
/lib64/libc.so.6[0x3886a75916]
./mystrings[0x400798]
./mystrings[0x40072f]
/lib64/libc.so.6(__libc_start_main+0xfd)[0x3886a1ecdd]
./mystrings[0x4005b9]
======= Memory map: ========
00400000-00401000 r-xp 00000000 00:1b 1921384528 /afs/pitt.edu/home/n/a/nap54/private/cs449/project2/mystrings
00600000-00601000 rw-p 00000000 00:1b 1921384528 /afs/pitt.edu/home/n/a/nap54/private/cs449/project2/mystrings
00601000-00622000 rw-p 00000000 00:00 0 [heap]
3886600000-3886620000 r-xp 00000000 fd:00 180 /lib64/ld-2.12.so
388681f000-3886820000 r--p 0001f000 fd:00 180 /lib64/ld-2.12.so
3886820000-3886821000 rw-p 00020000 fd:00 180 /lib64/ld-2.12.so
3886821000-3886822000 rw-p 00000000 00:00 0
3886a00000-3886b89000 r-xp 00000000 fd:00 183 /lib64/libc-2.12.so
3886b89000-3886d89000 ---p 00189000 fd:00 183 /lib64/libc-2.12.so
3886d89000-3886d8d000 r--p 00189000 fd:00 183 /lib64/libc-2.12.so
3886d8d000-3886d8e000 rw-p 0018d000 fd:00 183 /lib64/libc- 2.12.so
3886d8e000-3886d93000 rw-p 00000000 00:00 0
388d200000-388d216000 r-xp 00000000 fd:00 6639 /lib64/libgcc_s-4.4.6-20120305.so.1
388d216000-388d415000 ---p 00016000 fd:00 6639 /lib64/libgcc_s- 4.4.6-20120305.so.1
388d415000-388d416000 rw-p 00015000 fd:00 6639 /lib64/libgcc_s- 4.4.6-20120305.so.1
7ffff7fd5000-7ffff7fd8000 rw-p 00000000 00:00 0
7ffff7ffb000-7ffff7ffe000 rw-p 00000000 00:00 0
7ffff7ffe000-7ffff7fff000 r-xp 00000000 00:00 0 [vdso]
7ffffffea000-7ffffffff000 rw-p 00000000 00:00 0 [stack]
ffffffffff600000-ffffffffff601000 r-xp 00000000 00:00 0 [vsyscall]
Aborted (core dumped)
现在我完全迷失了。有人可以脱掉(更多?)洞察力吗?谢谢你的帮助,昨晚我没有得到太多(任何睡眠)这个项目(以及更重要的第二部分)今晚午夜到期......我明白我只是在粘贴我的代码并说“有它”,但我真的不知道从哪里开始,因为这是我第一次遇到像这样的崩溃。
答案 0 :(得分:2)
您真的应该学习如何使用gdb
等调试器。
一个明显的问题是您没有初始化next
结构中的header
字段。因此,当你去追加时,它会开始通过它,谁知道它可能会在哪里结束(不要假设字段被初始化为0)
答案 1 :(得分:2)
您的clear_list
函数释放列表的尾部然后重复。一旦它到达只剩下一个节点的点,它就会反复尝试释放first_node
。 clear_list
可以更简单地写成
void clear_list(struct node *first_node){
struct node *ptr = first_node;
struct node *next;
while (ptr != NULL) {
next = ptr->next_node;
free(ptr);
ptr = next;
}
}
Grijesh Chauhan最初指出的另一个问题是该行
printf("%s", conductor->ANSII);
错了。 conductor->ANSII
的类型为char
,因此您应使用%c
格式说明符来打印其值。
答案 2 :(得分:1)
你曾两次使用sizeof
,但两者都错了。
sizeof(1)
是int
的大小,因为1是int
常量。最有可能是4,典型的8位字节和32位int
。所以你的fread
试图将4个字节读入一个字符。那很糟糕。
另一方面,您几乎使用sizeof
推荐的安全malloc
惯用法:
p = malloc(sizeof *p);
但你忘记了*
。所以你要分配足够的空间来保存指向结构的指针,不足以容纳结构。
conductor->next_node = malloc(sizeof(*conductor->next_node));