标准输入/输出的重定向包括重定向到内存,或是重定向到文件。下面分别示例说明。
1、输入输出重定向到内存
setbuf函数具有打开和关闭缓冲机制。为了带缓冲进行I/O,参数buf必须指向一个长度为BUFSIZ(定义在stdio.h头文件中)的缓冲区。通常在此之后该流就是全缓冲的,但是如果该流与一个终端设备相关,那么某些系统也可以将其设置为行缓冲。为了关闭缓冲,可以将buf参数设置为NULL。
用 法: void setbuf(FILE *fp, char *buf);
示例:
#include <stdio.h>
char g_buffer[BUFSIZ] = {0}; //BUFSIZ为默认buffer大小,在stdio.h中定义
void main(void)
{
setbuf(stdout, g_buffer); //标准输出重定向到全局缓存区g_buffer
printf("Hello, world!\n");
setbuf(stdout, NULL); //恢复标准输出到stdout
printf("==>%s\n", g_buffer);
return;
}
[root@HLZ work]# gcc main.c
[root@HLZ work]# ./a.out
Hello, world!
==>Hello, world!
[root@HLZ work]#
2、输入输出重定向到文件
在C语言中,可以使用freopen将输入输出重定向到指定文件中。C语言的标准输入输出为stdin和stdout,这两个变量的数据类型为FILE *类型,也即标准输入输出操作,其本质还是文件操作。因此,
调用 freopen("input.log","r",stdin); 将标准输入重定向到input.log。
调用 freopen("output.log","w",stdout); 将标准输出重定向到output.log。
当调用freopen函数时,需要引用头文件stdio.h。
示例:
#include <stdio.h>
void main(void) {
FILE *fp = NULL;
char *filename = "output.log";
fp = freopen(filename,"w+",stdout); //标准输出重定向到文件output.log
if (NULL == fp)
{
fprintf(stderr,"error redirecting stdout\n");
return;
}
printf("Redirect stdout to %s\n", filename);
fclose(fp);
return;
}
[root@HLZ work]# gcc main.c
[root@HLZ work]# ./a.out
[root@HLZ work]# ls
a.out main.c output.log
[root@HLZ work]# cat output.log
Redirect stdout to output.log
[root@HLZ work]#
当标准输出stdout被重定向到指定文件后,如何把它重定向回原来"默认"的输出设备(即显示器)呢?
C标准库的回复是:不支持。没有任何方法可以恢复原来的输出流。
那是否存在依赖具体平台的实现呢?存在。
在操作系统中,命令行控制台(键盘或显示器)被视为一个文件。既然是文件,那么就有"文件名"。由于历史原因,命令行控制台文件在DOS系统和Windows操作系统中的文件名为"CON",在类Linux操作系统(如Unix、Mac OS X、Android等)中的文件名为"/dev/tty"。
所以,可以通过 fp = freopen("/dev/tty","w",stdout); 语句恢复Linux下的"默认"输出。