我想使用read()
和write()
方法来读取和写入控制台而不是原始scanf()
和printf()
,因为第一个方法有系统调用支持使用信号。
我必须制作一个迷你Unix shell,它在执行命令时会分叉。这是我最初尝试测试阅读和写作:
#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#define COMMAND_LENGTH 1024
#define NUM_TOKENS (COMMAND_LENGTH / 2 + 1)
void read_command(char *buff, char *tokens[], _Bool *in_background) {
// to be implemented later
}
void createStr(char **str) {
if (*str != NULL) {
free(*str);
*str = NULL;
}
*str = (char*)malloc(sizeof(char) * COMMAND_LENGTH);
}
void delStr(char** str) {
if (*str != NULL) {
free(*str);
*str = NULL;
}
}
int main(int argc, char *argv[]) {
char input_buffer[COMMAND_LENGTH];
char *tokens[NUM_TOKENS];
char *inp = NULL;
while (true) {
write(STDOUT_FILENO, "> ", strlen("> "));
createStr(&inp);
read(STDIN_FILENO, input_buffer, sizeof(char) * COMMAND_LENGTH);
strcpy(inp, input_buffer);
write(STDOUT_FILENO, inp, strlen(inp));
_Bool in_background = false;
read_command(inp, tokens, &in_background);
}
delStr(&inp);
return 0;
}
我的样本输入输出不是所需的输出。这是一个示例输出:
> Peterson
Peterson
��> Makr
Makr
son
��> Mark
Mark
son
��> Jon
Jon
son
��>
我不知道发生了什么。就像特殊字符出现的原因一样,以及在我的新输入中包含我最后输入的部分内容。我需要帮助。
答案 0 :(得分:0)
您必须存储read
的返回值,验证read
已完成并且在将字符串传递给strcpy
之前将其终止。 read
确实可以被信号中断,在这种情况下必须重新启动。 read
也可以返回部分行,你应该继续读取并连接到命令缓冲区,如果需要,小心地重新分配缓冲区,直到你收到字符'\n'
的文件结尾。