<stdio.h>
头文件中,是 C 语言标准库中的函数,专门用于重定向输入流(包括 scanf()、gets() 等)和输出流(包括 printf()、puts() 等)。值得一提的是,该函数也可以对 C++ 中的 cin 和 cout 进行重定向。#include <iostream> //cin、cout #include <string> //string #include <stdio.h> //freopen using namespace std; int main() { string name, url; //将标准输入流重定向到 in.txt 文件 freopen("in.txt", "r", stdin); cin >> name >> url; //将标准输出重定向到 out.txt文件 freopen("out.txt", "w", stdout); cout << name << "\n" << url; return 0; }执行此程序之前,我们需要找到当前程序文件所在的目录,并手动创建一个 in.txt 文件,其包含的内容如下:
C++
http://task.lmcjl.com/cplus/
<--控制台中,既不需要手动输入,也没有任何输出
与此同时,in.txt 文件所在目录下会自动生成一个 out.txt 文件,其包含的内容和 in.txt 文件相同:
C++
http://task.lmcjl.com/cplus/
<ios>
头文件中,专门用于实现 C++ 输入输出流的重定向。streambuf * rdbuf() const; streambuf * rdbuf(streambuf * sb);其中,第一种语法格式仅是返回一个指向当前流缓冲区的指针;第二种语法格式用于将 sb 指向的缓冲区设置为当前流的新缓冲区,并返回一个指向旧缓冲区的对象。
#include <iostream> #include <fstream> using namespace std; int main() { //打开 in.txt 文件,等待读取 ifstream fin("in.txt"); //打开 out.txt 文件,等待写入 ofstream fout("out.txt"); streambuf *oldcin; streambuf *oldcout; char a[100]; //用 rdbuf() 重新定向,返回旧输入流缓冲区指针 oldcin = cin.rdbuf(fin.rdbuf()); //从input.txt文件读入 cin >> a; //用 rdbuf() 重新定向,返回旧输出流缓冲区指针 oldcout = cout.rdbuf(fout.rdbuf()); //写入 out.txt cout << a << endl; //还原标准输入输出流 cin.rdbuf(oldcin); // 恢复键盘输入 cout.rdbuf(oldcout); //恢复屏幕输出 //打开的文件,最终需要手动关闭 fin.close(); fout.close(); return 0; }仍以前面创建好的 in.txt 文件为例,执行此程序后,控制台不会输出任何数据,而是会在该项目的目录下生成一个 out.txt 文件,其中就存有该程序的执行结果:
C++
http://task.lmcjl.com/cplus/
#include <iostream> #include <string> using namespace std; int main() { string name, url; cin >> name >> url; cout << name << '\n' << url; return 0; }通过编译、链接后,会生成一个 demo.exe 可执行文件,该执行文件可以双击执行,也可以在控制台上执行。例如,打开控制台(Windows 系统下指的是 CMD命令行窗口,Linux 系统下指的是 Shell 终端),并输入如下指令:
C:\Users\mengma>D:\demo.exe
C++ http://task.lmcjl.com/cplus/
C++
http://task.lmcjl.com/cplus/
C:\Users\mengma>D:\demo.exe <in.txt >out.txt
执行后会发现,控制台没有任何输出。这是因为,我们使用了"<in.txt"对程序中的 cin 输入流做了重定向,同时还用 ">out.txt"对程序中的 cout 输出流做了重定向。本文链接:http://task.lmcjl.com/news/14507.html