linux输出的重定向无效问题和解决
2023-12-13 08:08:02
我们在调试程序或者打印日志时经常会遇到重定向的问题,而有时候会遇到重定向无效的问题,下面给一个简单的例子,首先写一个简单的test.c
#include <stdio.h>
int main(){
fprintf(stdout, "hello\n");
fprintf(stderr, "world\n");
return 0;
}
编译生成可执行程序test,如果执行:
./test > log.txt
会有打印
world
而hello的内容会跑到log.txt里面,同样如果我们写个脚本运行:
output=`./test`
echo "*************************"
echo $output
打印结果如下:
world
*************************
hello
可以看到,hello跑到了output变量里面,而world没有,这是什么原因呢,显然关键在stdout和stderr。在linux系统,一旦创建一个进程,那么与之对应的会有三个数据流:stdin,stdout和stderr,对应的会创建三个文件:stdin,标准输入文件,通常对应着终端的键盘。stdout,标准输出文件,通常对应着终端的屏幕。stderr,标准错误输出文件,通常对应着终端的屏幕。
默认情况下,三个数据流对应的文件描述符分别是stdin—0,stdout—1,stderr—2,可通过代码查看:
#include <iostream>
#include <cstdio>
int main()
{
int stdinFd = fileno(stdin);
int stdoutFd = fileno(stdout);
int stderrFd = fileno(stderr);
std::cout << "stdinFd: " << stdinFd << std::endl;
std::cout << "stdoutFd: " << stdoutFd << std::endl;
std::cout << "stderrFd: " << stderrFd << std::endl;
return 0;
}
在默认的情况下,重定位对应的是描述符1:stdout,因此上述操作只会重定向第一个输出,如果想重定向第二个输出,可以选择2>(此时知会重定向描述符2也就是stderr),或者&> (同时重定向1和2)。
我们改为如下操作:
./test &> log.txt
就会实现两个输出的重定向,同样对应的脚本,可以写为:
#output=$(./test 2>&1)
output=`./test 2>&1`
echo "*************************"
echo $output
其中2>&1表示2重定向到1,对应输出为:
*************************
world hello
文章来源:https://blog.csdn.net/fangfanglovezhou/article/details/134546418
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!