关闭原有的stdout和stderr输出到控制台 ,重定向输入到log.txt和error.txt中
在这段代码里,标准输出和标准错误输出的重定向是通过关闭原有的文件描述符,再重新打开新文件来实现的。下面详细解释其重定向的实现原理和代码步骤:
实现原理
在 Unix 类系统(包括 Linux)以及类 Unix 环境下,每个进程在启动时都会默认打开三个标准的文件描述符:
STDIN_FILENO
(通常为 0):标准输入,一般关联到键盘。STDOUT_FILENO
(通常为 1):标准输出,一般关联到控制台。STDERR_FILENO
(通常为 2):标准错误输出,一般也关联到控制台。
文件描述符是一个非负整数,用于标识一个打开的文件、设备或网络连接等。重定向的核心思路就是关闭原有的标准输出和标准错误输出对应的文件描述符,然后重新打开新的文件,让新文件的文件描述符占据原来标准输出和标准错误输出的位置。
代码步骤分析
#include <stdio.h>
#include <unistd.h>
#include <fcntl.h>
int main()
{
// 步骤 1:关闭标准输出和标准错误输出对应的文件描述符
close(STDOUT_FILENO);
close(STDERR_FILENO);
// 步骤 2:打开新的文件,让新文件的文件描述符占据原来标准输出和标准错误输出的位置
// O_CREAT: 如果文件不存在则创建 O_RDWR: 读写模式 0644: 权限 O_APPEND: 追加模式写到文件后面
open("log.txt", O_CREAT | O_RDWR | O_APPEND, 0644); // fd 1 新的标准输出
open("error.txt", O_CREAT | O_RDWR | O_APPEND, 0644); // fd 2 新的标准错误输出
// 后续代码是正常的输入输出操作,由于重定向,输出会到相应文件
char input_buf[20];
fgets(input_buf, 20, stdin);
printf("input_buf: %s\n", input_buf);
fputs("使用stdout\n", stdout);
fflush(stdout);
fputs("使用stderr\n", stderr);
char stdin_buf[20];
read(STDIN_FILENO, stdin_buf, 20);
printf("stdin_buf: %s\n", stdin_buf);
write(STDOUT_FILENO, "使用STDOUT_FILENO\n", 20);
write(STDERR_FILENO, "使用STDERR_FILENO\n", 20);
return 0;
}