一个关于派生类与基类的赋值兼容有关问题

一个关于派生类与基类的赋值兼容问题
/*此为教程中的一个例子,但输出的结果与老师讲的不一致
应为:
B0::display()
B1::display()
D1::display()
但实际输出为:
B0::display()
B0::display()
B0::display()
请各位帮我看看为何不对,多谢了!
赋值兼容原则:
一、派生类的对象可以被赋值给基类的对象
二、派生类的对象可以初始化基类的引用
三、指向基类的指针也可以指向派生类*/
#include   <iostream.h>

class   B0     //基类B0声明
{
public:
void   display(){cout < < "B0::display() " < <endl;}
//公有成员函数
};

class   B1:public   B0
{
public:
void   display(){cout < < "B1::display() " < <endl;}
};

class   D1:public   B1
{
public:
void   display(){cout < < "D1::display() " < <endl;}
};

void   fun(B0   *ptr)
{
ptr-> display();
}//对象指针-> 成员名

void   main()
{
B0   b0;
B1   b1;
D1   d1;
B0   *p;//声明B0类指针
p=&b0;//B0类指针指向B0类对象
fun(p);
p=&b1;//B0类指针指向B1类对象
fun(p);
p=&d1;//B0类指针指向D1类对象
fun(p);
}

------解决方案--------------------
加上virtual就可以了,看看关于覆盖.
------解决方案--------------------

没错啊!这是覆盖啊!肯定输出的都是:B0::display()
除非在B0的成员函数前加virtual
你看书227的例子,和你刚才看的例子对比一下!