基类对象对派生类对象的切割问题

/*
 * *基类对象对派生类对象的切割问题* *
 程序输出:
 By_Value_Display :Window.display
 By_Reference_Display :WindowWithScrollBars.display
 知识点:
 *当一个derived class 对象以by value 方式传递并被视为一个base class 对象,base class 的拷贝构造函数
 *会被调用,而“造成此对象的行为像个derived class 对象”的那些特化性质全被切割掉了,仅仅留下一个
 *base class 对象,因为正是base class 构造函数建立了它。
 *避免切割问题,可用 pass-by-reference-to-const 代替 pass-by-value。
*/
#include <iostream>
using namespace std;


class Window
{
public:
 virtual void display() const { cout << "Window.display" << endl; };
};

class WindowWithScrollBars: public Window
{
public:
 virtual void display() const { cout << "WindowWithScrollBars.display" << endl; };
};

void By_Value_Display(Window w)
{
 w.display();
}

void By_Reference_Display(const Window& w)
{
 w.display();
}

int main()
{
 //调用
 WindowWithScrollBars wwsb;
 cout << "By_Value_Display :";
 By_Value_Display(wwsb);
 cout << "By_Reference_Display :";
 By_Reference_Display(wwsb);

 getchar();

}

你可能感兴趣的:(基类对象对派生类对象的切割问题)