[英]Inherited template class member tests fine in chain constructor, but is “lost” thereafter
我的基类class Foo
是一个模板类,它具有以下构造函数:
//Declarations
template <class T>
class Foo
{
public:
Foo::Foo(std::string& root);
MemberClass obj;
}
template <class T>
Foo<T>::Foo(std::string& root)
{
MemberClass obj(root); // initialize the member object
obj.getRoot(); // Prints the string
// ...
}
它有一个子类,其构造如下:
template <class T>
Bar<T>::Bar(std::string& root)
: Foo<T>(root)
{
//...
}
template<class T>
void
Bar<T>::accessObj()
{
this->obj.getRoot();
// Prints the empty string
}
即使没有错误生成,这也会带来意外的行为。 在这种情况下, getRoot()
将返回空字符串。
我已经通过更改Foo
构造函数进行了测试,如下所示:
{
MemberClass obj(root);
std::cout << &obj << std::endl;
}
和Bar
构造函数是这样的:
//...
: Foo<T>(root)
{
std::cout << &this->obj << std::endl;
}
输出给出了内存中的两个不同位置,这完全让我震惊。 为什么会这样呢? 我如何解决它?
您的构造函数最好如下所示:
template <class T>
Foo<T>::Foo(std::string& root)
: obj(root) // initialize the member object
{
obj.getRoot(); // Prints the string
// ...
}
以前,您是在Foo构造函数中构造一个临时obj
并将其丢弃,根本没有初始化您的成员变量。
如果您使用的是GCC,则-Wshadow选项可能有助于捕获此错误。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.