【发布时间】:2012-02-10 12:24:11
【问题描述】:
这个例子取自 Bruce Eckel 的“Thinking in C++”第 14 章“Upcasting and the Copy Constructor”一节。
#include <iostream>
using namespace std;
class Parent
{
int i;
public:
Parent(int ii) : i(ii) { cout << "Parent(int ii)\n"; }
Parent(const Parent& b) : i(b.i) { cout << "Parent(const Parent&)\n"; }
Parent() : i(0) { cout << "Parent()\n"; }
friend ostream& operator<<(ostream& os, const Parent& b)
{ return os << "Parent: " << b.i << endl; }
};
class Member
{
int i;
public:
Member(int ii) : i(ii) { cout << "Member(int ii)\n"; }
Member(const Member& m) : i(m.i) { cout << "Member(const Member&)\n"; }
friend ostream& operator<<(ostream& os, const Member& m)
{ return os << "Member: " << m.i << endl; }
};
class Child : public Parent
{
int i;
Member m;
public:
Child(int ii) : Parent(ii), i(ii), m(ii) { cout << "Child(int ii)\n"; }
friend ostream& operator<<(ostream& os, const Child& c)
{ return os << (Parent&)c << c.m << "Child: " << c.i << endl; }
};
int main() {
Child c(2);
cout << "calling copy-constructor: " << endl;
Child c2 = c;
cout << "values in c2:\n" << c2;
}
作者对此代码发表以下评论:
"Child 的运算符
return os << (Parent&)c << c.m << "Child: " << c.i << endl;
我也运行程序,将上面的指令替换为:
return os << (Parent)c << c.m << "Child: " << c.i << endl;
并且程序运行没有问题,只有一个预期的差异。现在再次调用Parent 复制构造函数将参数c 复制到Parent::operator<<()。
那么,作者所说的不良结果是什么?
【问题讨论】:
-
@ephemient 我没有看到这里切片有问题
-
不是这里有问题,而是一般情况下可能有问题。
-
还有从
const转换为非const对象的问题。(Parent&)c应该是(const Parent &)c吗? -
@EdHeal:是的。更一般地说,这里不需要强制转换。
return表达式之前的简单Parent& p = c;语句就足够了。
标签: c++ inheritance upcasting object-slicing