标准错误
上一篇系统IO的博客中,介绍了系统默认打开的三种文件描述符:标准输入,标准输出和标准错误,但是在测试的时候发现,把文件内容重定向到标准输出和标准错误时,都能在屏幕上打印出来,例如:
const char* msg1="hello 标准输出\n";
write(1,msg1,strlen(msg1));
const char* msg2="hello 标准错误\n";
write(2,msg2,strlen(msg2));
那这标准输出和标准错误又有什么区别呢?下面来测试一下重定向功能。
从结果可以看到,在重定向的时候,只有标准输出被重定向到文本文件中了,如果想要实现标准错误的重定向,还需要加上这个命令,后面加上的命令可以理解为将1里面的内容拷贝到2中,2也指向目标文件
./redir > log.txt 2>&1
缓冲区
运行如下的一段代码,来看看运行结果:
const char* msg1="hello 标准输出\n";
write(1,msg1,strlen(msg1));
const char* msg2="hello 标准错误\n";
write(2,msg2,strlen(msg2));
printf("hello printf\n");