1、派生类到基类的转换
如果有一个派生类型的对象,则可以使用它的地址对基类类型的指针进行赋值或初始化。同样,可以使用派生类型的引用或对象初始化积累类型的引用。严格说来,对对象没有类似转换。编译器不会自动将派生类型对象转换成基类类型对象。
1.1 引用转换不同于转换对象
将派生类型的对象传给希望接受基类引用的函数时,引用直接绑定到该对象,虽然看起来是在传递对象。转换不会改变派生类型对象,该对象仍然是派生类型对象。
当将派生类型对象传给希望接受基类类型对象的函数时,情况完全不同。这时该派生类对象的基类部分被复制到形参。
1.2 用派生类对象对基类对象进行初始化或赋值
用派生类对象对基类对象赋值有两种情况
(1) 基类显式定义了将派生类型对象赋值或复制给基类对象的函数,即构造函数或赋值运算符来实现,这时根据用户定义的动作来进行转换。
(2)未定义上述操作,则派生类的非基类成员被切掉,只将基类部分赋值给基类对象。
1.3 派生类到基类转换的可访问性
关于这个问题,在C++ primer 4 中文版上翻译的很恶心,如下:
这一段我到现在没弄明白,写了一段代码验证:
从中可以发现,假设类层次如下
base;
son:private base;
grandson: xxx son;
则在grandson中甚至都不能定义base类型的对象,自然也就不存在什么访问权限的问题了,而如果son的继承方式是son:protected base,则没有问题,但是son仍然不能传递给一个base类型的引用或指针
上面的代码稍作改动就可以通过:
2、基类到派生类的转换
基类到派生类的自动转换是不存在的,将基类对象赋值给派生类会出现错误。