![](/img/trans.png)
[英]Why does the (!(feof(sp)) && end) never evaluate to true?
[英]feof becomes true prematurely
我试图通过一次读取一个字符来通过套接字发送文件,直到缓冲区(字符数组)已满,发送它,然后重复直到文件结束。 但是由于某种原因 feof 在文件结束之前变为真(我相信可能是在缓冲区数组已满时)。
int c;
int end_loop = 1;
char to_send[BUFFER_LENGTH];
while (end_loop == 1) { //For the entire file
printf("creating next data\n");
bzero(to_send, BUFFER_LENGTH);
for (int i = 0; i < BUFFER_LENGTH - 1; i++) { // read data from file until buffer full or EOF
c = fgetc(f);
if (c == EOF) { // If end of file break loop
printf("EOF\n");
end_loop = 0;
break;
}
to_send[i] = c;
}
for (int i = 0; i < strlen(to_send); i++) {
printf("%c", to_send[i]);
}
n = write(sockfd, to_send, strlen(to_send));
if (n < 0) {
perror("ERROR writing to socket");
exit(1);
}
}
n = write(sockfd, "EOF", 3);
if (n < 0) {
perror("ERROR writing to socket\n");
exit(1);
}
feof 可能不是问题,因为尽管遇到了“EOF”,但代码似乎仍在循环。
编辑:添加了评论中的建议。 错误仍然发生。
代码需要跟踪读取了多少个字符,然后printf(), write()
跟踪了多少个字符。
while (end_loop == 1) {
...
// for (int i = 0; i < BUFFER_LENGTH - 1; i++) {
int i;
for (i = 0; i < BUFFER_LENGTH - 1; i++) {
...
}
// for (int i = 0; i < BUFFER_LENGTH - 1; i++) {
// printf("%c", to_send[j]);
for (int j = 0; j < i; j++) {
...
// n = write(sockfd, to_send, BUFFER_LENGTH);
n = write(sockfd, to_send, i);
...
}
其他问题包括
测试EOF
,不仅是feof(f)
c = fgetc(f);
// if (feof(f)) { // If end of file break loop
if (c == EOF) { // If end of file break loop **or input error**
填充char
数组时不需要 -1。 -1 可能对字符串有用,但在这里使用字符串也不是最好的主意,因为fgetc()
可能返回一个空字符。
// vvv
// for (int i = 0; i < BUFFER_LENGTH - 1; i++)
for (int i = 0; i < BUFFER_LENGTH; i++)
// or better
size_t i;
for (i = 0; i < sizeof to_send; i++)
OP 修正代码 mid-answer Hmmmmmmmm。
不要使用for (int i = 0; i < strlen(to_send); i++) {
。 读取的数据可能包含空字符,这在此处否定了字符串的良好使用。
如果OP不想在最后一行之前看到"EOF\\n"
,则在while
循环后打印"EOF\\n"
。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.