C++多态与引用

Mon*_*n45 3 c++ polymorphism reference

我一直在用C++编写一些操作文件的类.当我开始时,我让所有构造函数接受一个std::string被解释为文件名的参数,因为这很快捷.

std::fstream任何类使用的唯一函数是.open().我认为既然std::ofstream并且std::ostringstream两者都派生自std::ostream并且我只使用了std::ostream函数,那么让每个构造函数都适当地接受一个std::ostream或者std::istream参数,而不是将类绑定到文件上会好得多.

一个伟大的教科书例子,为什么多态是有用的.海湾合作委员会对此非常不满.这是我的代码的简化:

#include <iostream>
#include <fstream>

class Foo {
        public:
                Foo(std::istream&);
                std::istream& input;
};

Foo::Foo(std::istream& is) {
        this->input = is;
}

int main() {
        std::ifstream is("test.txt");
        Foo foo(is);
}
Run Code Online (Sandbox Code Playgroud)

在编译时g++ test.cpp,会产生以下各种各样的错误:

test.cpp: In constructor ‘Foo::Foo(std::istream&)’:
test.cpp:10:1: error: uninitialized reference member ‘Foo::input’ [-fpermissive]
In file included from /usr/include/c++/4.7/ios:43:0,
                 from /usr/include/c++/4.7/ostream:40,
                 from /usr/include/c++/4.7/iostream:40,
                 from test.cpp:1:
/usr/include/c++/4.7/bits/ios_base.h: In member function ‘std::basic_ios<char>& std::basic_ios<char>::operator=(const std::basic_ios<char>&)’:
/usr/include/c++/4.7/bits/ios_base.h:791:5: error: ‘std::ios_base& std::ios_base::operator=(const std::ios_base&)’ is private
In file included from /usr/include/c++/4.7/ios:45:0,
                 from /usr/include/c++/4.7/ostream:40,
                 from /usr/include/c++/4.7/iostream:40,
                 from test.cpp:1:
/usr/include/c++/4.7/bits/basic_ios.h:64:11: error: within this context
In file included from /usr/include/c++/4.7/iostream:41:0,
                 from test.cpp:1:
/usr/include/c++/4.7/istream: In member function ‘std::basic_istream<char>& std::basic_istream<char>::operator=(const std::basic_istream<char>&)’:
/usr/include/c++/4.7/istream:56:11: note: synthesized method ‘std::basic_ios<char>& std::basic_ios<char>::operator=(const std::basic_ios<char>&)’ first required here 
test.cpp: In constructor ‘Foo::Foo(std::istream&)’:
test.cpp:11:16: note: synthesized method ‘std::basic_istream<char>& std::basic_istream<char>::operator=(const std::basic_istream<char>&)’ first required here 
Run Code Online (Sandbox Code Playgroud)

我无法筛选所有模板参数,但看起来它不喜欢this->input = is;.每个类都能够作为成员访问流是很重要的,因为各种不同的成员函数都必须能够看到它.我认为GCC可能对指针更好一些,但对我来说,指向类的指针看起来像是动态分配的内存,我只想提出这些怀疑,如果它们是真的.什么是正确的方法?

And*_*owl 10

const必须在构造函数初始化列表中初始化引用类型的成员(以及类型的成员):

Foo::Foo(std::istream& is) : input(is)
//                         ^^^^^^^^^^^
{
}
Run Code Online (Sandbox Code Playgroud)

原因是您需要在使用它之前立即初始化引用.您原始代码中的内容是非法的,原因与此相同:

int y = 42;
int& x; // ERROR!
x = y;
Run Code Online (Sandbox Code Playgroud)

另一方面,初始化列表保证输入构造函数体之前,引用成员绑定到对象.