7

当我尝试编译代码时

istream in;
if (argc==1)
        in=cin;
else
{
        ifstream ifn(argv[1]);
        in=ifn;
}

gcc 失败,抱怨这operator=是私人的。有没有办法istream根据条件设置不同的值?

4

4 回答 4

5

您可以使用指针in,例如:

istream *in;
ifstream ifn;

if (argc==1) {
     in=&cin;
} else {
     ifn.open(argv[1]);
     in=&ifn;
}
于 2010-03-09T06:52:49.707 回答
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);
    }
}
于 2010-03-09T06:47:58.350 回答
4

您可以将 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 会避免未定义的行为。

于 2010-03-09T06:54:26.600 回答
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'
  // ...
}
于 2010-03-09T06:55:28.910 回答