当我尝试编译代码时
istream in;
if (argc==1)
in=cin;
else
{
ifstream ifn(argv[1]);
in=ifn;
}
gcc失败,抱怨operator=
是私有的。有没有办法根据条件将istream
设置为不同的值?
答案 0 :(得分:5)
您可以使用in
的指针,例如:
istream *in;
ifstream ifn;
if (argc==1) {
in=&cin;
} else {
ifn.open(argv[1]);
in=&ifn;
}
答案 1 :(得分:4)
那么,是不是抱怨“没有合适的构造函数”?无论如何,你可以修改如下。
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);
}
}
答案 2 :(得分:4)
你可以用另一个替换cin的streambuf,在某些程序中,这比传递istreams而不直接引用cin的一般策略更简单。
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;
}
尽管在控制离开main之后使用cin是极其罕见的,但如果你的程序可能会这样做,上面的try-catch会避免未定义的行为。
答案 3 :(得分:1)
你不能影响这样的流。您可以使用指向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'
// ...
}