将 cout 分配给变量名
在 ANSI C++ 中,如何将 cout 流分配给变量名? 我想要做的是,如果用户指定了输出文件名,我将输出发送到那里,否则,将其发送到屏幕。 所以类似:
ofstream outFile;
if (outFileRequested)
outFile.open("foo.txt", ios::out);
else
outFile = cout; // Will not compile because outFile does not have an
// assignment operator
outFile << "whatever" << endl;
我也尝试将其作为宏函数执行:
#define OUTPUT outFileRequested?outFile:cout
OUTPUT << "whatever" << endl;
但这也给了我一个编译器错误。
我想我可以为每个输出使用 IF-THEN 块,但如果可以的话我想避免这种情况。 有任何想法吗?
In ANSI C++, how can I assign the cout stream to a variable name? What I want to do is, if the user has specified an output file name, I send output there, otherwise, send it to the screen. So something like:
ofstream outFile;
if (outFileRequested)
outFile.open("foo.txt", ios::out);
else
outFile = cout; // Will not compile because outFile does not have an
// assignment operator
outFile << "whatever" << endl;
I tried doing this as a Macro function as well:
#define OUTPUT outFileRequested?outFile:cout
OUTPUT << "whatever" << endl;
But that gave me a compiler error as well.
I supposed I could either use an IF-THEN block for every output, but I'd like to avoid that if I could. Any ideas?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(7)
使用参考。 请注意,引用的类型必须是
std::ostream
,而不是std::ofstream
,因为std::cout
是一个std::ostream
,因此您必须使用最小公分母。Use a reference. Note that the reference must be of type
std::ostream
, notstd::ofstream
, sincestd::cout
is anstd::ostream
, so you must use the least common denominator.我假设你的程序的行为类似于标准的unix工具,当没有给定一个文件时,它将写入标准输出,当给定一个文件时,它将写入该文件。 您可以重定向
cout
以写入另一个流缓冲区。 只要您的重定向有效,写入 cout 的所有内容都会透明地写入您指定的目的地。 一旦重定向对象超出范围,原始流就会被放入,输出将再次写入屏幕:现在,只要管道在 main 中处于活动状态,cout 就会重定向到文件。 您可以通过使其不可复制来使其更加“生产就绪”,因为它还没有准备好被复制:如果副本超出范围,它将已经恢复原始流。
I assume your program behaves like standard unix tools, that when not given a file will write to standard output, and when given a file will write into that file. You can redirect
cout
to write into another stream buffer. As long as your redirection is alive, everything written to cout is transparently written to the destination you designated. Once the redirection object goes out of scope, the original stream is put and output will write to the screen again:Now, cout is redirected to the file as long as the pipe is alive in main. You can make it more "production ready" by making it non-copyable, because it's not ready to be copied: If the copy goes out of scope, it would restore the original stream already.
您可以在这里找到有关如何执行此操作的非常详细的说明:
http://groups.google.com/group/ comp.lang.c++/msg/1d941c0f26ea0d81?pli=1
希望有人能更清楚地写出这一点,以便堆栈溢出能够得分......
You can find a very detailed explanation of how to do this here:
http://groups.google.com/group/comp.lang.c++/msg/1d941c0f26ea0d81?pli=1
Hopefully someone will write this up more clearly for stack overflow to take the points...
遵循 Adam Rosenfield 的轨迹,但修复了使用三元和逗号运算符的引用初始化问题:(
在 VS 中测试)
Following Adam Rosenfield's tracks, but fixing the reference initialization problem with ternary and comma operators:
(Tested in VS)
我认为 Adam 走在正确的轨道上,但我不认为你可以分配引用 - 你需要使用指针:然后
你可以将引用定义为指针的值,但它不会是全局的
I think Adam's on the right track but I don't think you can assign references - you need to use a pointer instead:
you could then define a reference to be the value of the pointer, but it wouldn't be global
我不确定您是否可以将 cout 分配给 ofstream 类型的变量。 cout 是 ostream 类型的对象(而 cin 是 istream 类型),我不确定其中一个是从另一个继承的。 因此,也许检查文件是否已给定/存在并创建适当的流类型将是更好的方法。
I'm not sure that you can assign cout to a variable of type ofstream. cout is an object of type ostream (whereas cin is of type istream) and I'm not sure that one inherits from the other. So, maybe something checking to see if a file was given/exists and creating the appropriate stream type would be a better approach.
这花了大约两个小时才得到。 基本上,我有一个运行测试套件的外部类。 我发送委托来运行测试,因此为了访问输出,我需要发送输出流。 我想我可以为每个测试做不同的流。 无论如何,我想传入ofstream以供稍后使用。
This took about two hours to get. Basically, I have a external class running a test suite. I send in a delegate to run the tests, so in order to have access to output I need to send in an output stream. I guess I could have done a different stream per test. Anyways, I wanted to pass in the ofstream to be used later.