遗留问题的解决
我们之前写输出重定向的时候遇到了一个问题。
代码:
运行结果
我们发现内容并没有重定向,也没有输出到显示器上。
这是为什么?经过之前的学习,我们可以知道数据会暂存在stdout的缓冲区中,但是因为我们最后关闭了对应fd,所以数据便无法刷新了,所以我们要提前fflush内容。
运行结果
stdout、stderr的区别
我们知道stdout、stderr都是显示器文件那么它们之间有什么区别呢?
来段代码帮助我们区别
运行代码:
我们看到确实全都打印到显示器上了。那么如果我们对这些内容重定向会怎么样?
我们看到stdout的内容全部重定向到log.txt中了,但是stderr的内容还是打印到了显示器上。
所以我们就可以明白,1和2对应的都是显示器文件,但是他们两个是不同的,如同认为,同一个显示器文件,被打开了两次!
所以重定向结果才会如上所示。
一般而言如果程序运行有可能会有问题的话,建议使用stderr或者cerr来打印。
如果是常规的文本内容,我们建议用cout、stdout打印
但是如果我们就像全部打印到同一个文件呢?
原理
还可以
perror()向2号文件描述符写入,我们之前一直用perror是因为代码错误errno就会被设置,所以perror就能打印出错误。
自己设计perror。