gpt4 book ai didi

c - 将字符读入有限的缓冲区大小

转载 作者:太空宇宙 更新时间:2023-11-04 05:00:53 25 4
gpt4 key购买 nike

我有一个程序接收字符并将它们读入一个有限大小的缓冲区(在本例中为 64)。如果用户输入超过 64 个字符,它必须拒绝整个输入字符串,警告用户他们输入了太多字符,然后重新开始。如果用户点击 ctrl-D , 这是一个文件结尾,程序必须退出。

所以我的设计如下:让实际的底层缓冲区有 65 个字符来容纳换行符。如果最后一个字符不是换行符,则用户点击 ctrl-D ,所以程序退出。如果缓冲区已满(即它包含 65 个字符)并且最后一个不是换行符,则程序假定给出的字符太多,因此它进入循环并不断将输入读入缓冲区,直到缓冲区读取in 以换行符结尾(在这种情况下它警告用户限制并重新开始),或者它被缩短而不以换行符结尾(在这种情况下程序终止)。

我的问题是,我该如何处理用户刚好输入 65 个字符(或 65 的整数倍),然后点击 ctrl-D 的情况? ?正如程序目前所处的那样,当缓冲区已满并且没有以换行符结尾时,它假定存在溢出,但在这种情况下我希望程序终止。如何让程序在收到 65 个字符的标量倍数和 ctrl-D 后终止? ?

#include <string.h>
#include <unistd.h>

#define BUFSIZE ( 65 )


int main( int argc, char* argv[] ) {
char* prompt = "myshell->";
char* tooMany = "Max characters (64) exceeded.\n";
int numInput;
int done = 0;
char input[ BUFSIZE ];
while( !done ) {
int cont = 0;

write( STDOUT_FILENO, prompt, strlen( prompt ) );
numInput = read( STDIN_FILENO, input, BUFSIZE );
if( input[ numInput - 1 ] == '\n' ) {
cont = 1;
} else {
if( numInput != BUFSIZE ) {
done = 1;
write( STDOUT_FILENO, "\n", strlen( "\n" ) );
} else {
int spill = 1;
while( spill ) {
numInput = read( STDIN_FILENO, input, BUFSIZE );
if( input[ numInput - 1 ] == '\n' ) {
spill = 0;
write( STDOUT_FILENO, tooMany, strlen( tooMany ) );
} else {
if( numInput != BUFSIZE ) {
spill = 0;
done = 1;
write( STDOUT_FILENO, "\n", strlen( "\n" ) );
}
}
}
}
}

/*done ingesting input. Now do something with it...*/
if( cont ) {
write( STDOUT_FILENO, input, numInput );
}

}
return 0;
}

约束:我只能使用 readwrite功能,但不是来自 <stdio.h> 的任何东西.

最佳答案

你真的应该接受任意大小的线条。注意读取 tty -例如。在终端中-不同于阅读,例如一些管道。 (伪 tty-s 是一个复杂的话题:一些行缓冲发生在内核中)。

并且您应该有一些缓冲 - 您通常可以读取比您需要的字节更多的字节,因此将额外的字节保留在缓冲区中以供将来使用。

因此您应该malloc 缓冲区(并在太小时重新分配它)。如果您的老师不允许 malloc,请使用 mmap

实现您自己的分配器

仔细阅读read(2)手册页。不要忘记它可以在错误时返回 -1,在文件结束时返回 0,或者在成功时返回一些计数。

关于c - 将字符读入有限的缓冲区大小,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18169269/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com