基类和派生类对象之间的赋值
2004-07-31 21:29
295 查看
class A
{
}
Class B:public A
{
}
A aobject;
B bobject;
有关
(1)aboject=bobject;
(2)bobject=aboject;
的说明。
=============================================================================
(1)aobject=bobject; 调用default A::operator =,由编译器自动生成,它的函数声明大致类似于:A operator = (A rhs),反正=号右边要求是一个A的对象,bobject作为A的子类对象亦是可行的,只不过传递过程中会产生“截断”。
(2)bobject=aobject; 调用default B::operator =,也由编译器自动生成,它的函数声明大致类似于:B operator = (B rhs),这里=号右边要求是一个B的对象,aobject这时就不可行了。
这时,单单重载B::operator =也无济于事,因为你无法改变operator = 函数参数必须是B对象的这个事实。要实现bobject=aobject;可以重载强制类型转换函数,也可以利用编译器隐式类型转换的能力,如:
class A
{
public:
A(){}
};
class B:public A
{
public:
B(){}
B(A a){}
};
A aobject;
B bobject;
int main()
{
aobject=bobject;
bobject=aobject;
return 0;
}
ps:这是我在csdn论坛上的一个问题,感谢RookieStar(★)(巴巴罗萨) 等网友的回答。
{
}
Class B:public A
{
}
A aobject;
B bobject;
有关
(1)aboject=bobject;
(2)bobject=aboject;
的说明。
=============================================================================
(1)aobject=bobject; 调用default A::operator =,由编译器自动生成,它的函数声明大致类似于:A operator = (A rhs),反正=号右边要求是一个A的对象,bobject作为A的子类对象亦是可行的,只不过传递过程中会产生“截断”。
(2)bobject=aobject; 调用default B::operator =,也由编译器自动生成,它的函数声明大致类似于:B operator = (B rhs),这里=号右边要求是一个B的对象,aobject这时就不可行了。
这时,单单重载B::operator =也无济于事,因为你无法改变operator = 函数参数必须是B对象的这个事实。要实现bobject=aobject;可以重载强制类型转换函数,也可以利用编译器隐式类型转换的能力,如:
class A
{
public:
A(){}
};
class B:public A
{
public:
B(){}
B(A a){}
};
A aobject;
B bobject;
int main()
{
aobject=bobject;
bobject=aobject;
return 0;
}
ps:这是我在csdn论坛上的一个问题,感谢RookieStar(★)(巴巴罗萨) 等网友的回答。
相关文章推荐
- 基类对象和派生类对象之间的赋值关系
- 基类和派生类对象之间的赋值(截断)
- C++:基类与派生类对象之间的赋值兼容关系
- 基类对象和派生类对象之间的赋值关系
- 二义性、虚函数、纯虚函数、虚基类、抽象类、基类对象与派生类对象之间赋值兼容原则
- c++,派生类对象可以对基类赋值,基类对派生类不可以赋值
- C++ 基类与派生类之间的相互引用、赋值问题
- 关于基类与派生类之间对象、指针等转化关系的小结
- 对基类与派生类对象和指针赋值的小结
- 对基类与派生类对象和指针赋值的小结
- 派生类与基类之间的对象模型
- 对基类与派生类对象和指针赋值的小结
- 派生类的对象赋值给基类对象
- 派生类与基类之间的对象模型
- 与基类对象和派生类对象相关的赋值兼容问题
- C++中派生类之间的赋值对基类的影响
- 关于基类与派生类之间对象、指针等转化关系的小结
- 基类的指针指向派生类的对象
- 为什么基类指针和引用可以指向派生类对象,但是反过来不行?
- C++中,基类的指针指向派生类的对象