下面的代码读取同一目录中的文本文件,并以相反的顺序打印文件中的每一行。例如,我读过的文本文件:
line 1
line 2
line 3
这将打印出来:
第 3
行第 2 行
行第 1 行
确实如此,那么真正的问题是什么?这个问题与其说是修复一些我在编写时得到一点帮助的代码的功能,不如说是关于理解代码及其背后的逻辑以及它是如何完成的。
我对C很陌生(已经学习了几天),所以如果我不明白相对简单的东西,请不要尖叫。
问题:
在第一个while循环中,我分配了足够大的内存块来存储结构类型'line',并定义了'line'类型的指针'l1'来保存这个分配内存的地址。现在问题来了。在下面的代码行中,为一个字符串分配了另一个内存块,该字符串的缓冲区足够大,可以容纳在指针定义为 l1->lines 的文本文件中读取的每个字符串的大小。
对我来说,这似乎不合逻辑,因为“l1”仅被定义为“line”类型的指针,但在这个 while 循环的第二行,“l1->lines”表明我已经声明了一个“line”类型的结构命名为“l1”,我正在访问它的一个成员(“行”),并将这个结构成员的地址分配为新分配的内存块的地址。这意味着 'l1' 是一个指向结构的指针,也是一个指向内存块的指针。
从这一切我可以清楚地说,我对正在发生的事情的理解是有偏差的,绝不是正确的。有人可以请教我什么似乎是微不足道的问题吗?
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
typedef struct line {
char *lines;
struct line *prev;
} line;
FILE *file;
int main() {
line *tail = NULL;
file = fopen("text.txt","r");
char line1[80];
while (fgets(line1,80,file)!=NULL) {
line *l1 = malloc(sizeof(line));
l1->lines = malloc(strlen(line1)+1);
strcpy(l1->lines,line1);
l1->prev = tail;
tail = l1;
}
line *current;
current = tail;
while (current != NULL) {
printf("%s\n",current->lines);
current = current->prev;
}
return 0;
}