我正在尝试逐行读取标准文件输入。
这是我的代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#define BUFFER_SIZE 1204
char* readLine(char* buffer){
int i = 0;
for(i; i< BUFFER_SIZE; i++){
printf("%c",buffer[i]);
if( '\n' == buffer[i]){
char* line[124];
memcpy( line, &buffer[0], i-1 );
return *line;
}
}
free(buffer);
}
int doStuffWithLine(char* line){
return 1;
}
int main(int argc, char *argv[])
{
ssize_t aux1;
char *buffer = malloc(sizeof(char)*BUFFER_SIZE);
char *line = malloc(sizeof(char)*BUFFER_SIZE);
while((read(STDIN_FILENO, buffer, BUFFER_SIZE))>0){
line = readLine(buffer);
doStuffWithLine(line);
printf("%s", line);
}
return 0;
}
这是输入文件的内容:
lol1
lol2
lol3
这是我程序的输出:
lol1
Segmentation fault (core dumped)
我想知道如何阅读第2行和第3行,以及如何解决我做错的事情,因为我不理解问题。
谢谢。
答案 0 :(得分:1)
函数read
读取原始字节,并且不会以字符串终止符'\0'
终止缓冲区;然后将其用于需要printf("%s",...)
终止的C字符串的0
,会产生不确定的行为(例如崩溃)。
我建议改用fgets
。
答案 1 :(得分:0)
首先,谢谢所有帮助我并花了一些时间尝试的人。
花了几个小时学习并动脑筋之后,我找到了解决方案。最后,我是*****和菜鸟。
如果有人遇到相同的问题,我将提交我的代码。轻松自在:
$ echo 'hello world' | node stdin.js
hello world