当我尝试编译代码时
istream in;
if (argc==1)
in=cin;
else
{
ifstream ifn(argv[1]);
in=ifn;
}
gcc 失败,抱怨这operator=
是私人的。有没有办法istream
根据条件设置不同的值?
您可以使用指针in
,例如:
istream *in;
ifstream ifn;
if (argc==1) {
in=&cin;
} else {
ifn.open(argv[1]);
in=&ifn;
}
那么,它不是在抱怨“没有合适的构造函数可用”吗?无论如何,您可以按如下方式对其进行修改。
void Read(istream& is)
{
string line;
while (getline(is, line))
cout << line;
}
int main(int argc, char* argv[])
{
if (argc == 1)
Read(cin);
else
{
ifstream in("sample.txt");
Read(in);
}
}
您可以将 cin 的 streambuf 替换为另一个,并且在某些程序中,这比在不直接引用 cin 的情况下传递 istreams 的一般策略更简单。
int main(int argc, char* argv[]) {
ifstream input;
streambuf* orig_cin = 0;
if (argc >= 2) {
input.open(argv[1]);
if (!input) return 1;
orig_cin = cin.rdbuf(input.rdbuf());
cin.tie(0); // tied to cout by default
}
try {
// normal program using cin
}
catch (...) {
if (orig_cin) cin.rdbuf(orig_cin);
throw;
}
return 0;
}
尽管在 control 离开 main 之后使用 cin 是非常罕见的,但如果这是您的程序可能会做的事情,上面的 try-catch 会避免未定义的行为。
你不能像这样影响流。但是,您可以使用指向 istream 的指针来获得您想要实现的目标。
#include <fstream>
#include <istream>
#include <iostream>
using namespace std;
int main(int argc, char *argv[])
{
istream *in;
// Must be declared here for scope reasons
ifstream ifn;
// No argument, use cin
if (argc == 1) in = &cin;
// Argument given, open the file and use it
else {
ifn.open(argv[1]);
in = &ifn;
}
return 0;
// You can now use 'in'
// ...
}