使用read()和write()代替C

时间:2016-02-09 22:29:05

标签: c shell command-line include fork

我想使用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
��>

我不知道发生了什么。就像特殊字符出现的原因一样,以及在我的新输入中包含我最后输入的部分内容。我需要帮助。

1 个答案:

答案 0 :(得分:0)

您必须存储read的返回值,验证read已完成并且在将字符串传递给strcpy之前将其终止。 read确实可以被信号中断,在这种情况下必须重新启动。 read也可以返回部分行,你应该继续读取并连接到命令缓冲区,如果需要,小心地重新分配缓冲区,直到你收到字符'\n'的文件结尾。