c++中向上转型(安全)和向下转型(不安全)
//基本的向上构造
为康乐等地区用户提供了全套网页设计制作服务,及康乐网站建设行业解决方案。主营业务为网站设计制作、网站设计、康乐网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
#include
using namespace std;
class A{
public:
void myfunc(){
cout << "A myfunc" << endl;
}
virtual void mytest(){
cout << "A mytest" << endl;
}
};
class B:public A{
public:
void myfunc(){
cout << "B myfunc" << endl;
}
virtual void mytest(){
cout << "B mytest" << endl;
}
};
int main(void){
A* pa = new A();
B* pb = new B();
pa = pb;//向上转型,隐式的,是安全的(pb = static_cast(pa)是向下转型,不安全的.)
pb->myfunc();//B myfunc
pb->mytest();//B mytest
pa->myfunc();//A myfunc
pa->mytest();//B mytest 向上转型达到,多态的目的.
return 0;
}
//向上转型+虚函数 #includeusing namespace std; class Integer{ public: Integer(int r):m_r(r){} virtual Integer& operator+=(const Integer& that){//虚函数可以为拷贝构造函数. m_r +=that.m_r; return *this; } int m_r; }; class Complex:public Integer{ public: Complex(int r,int i):Integer(r),m_i(i){} Complex& operator+=(const Integer& c){//这里向上转型,这样 //形参既可以接受Integer也可以接受Complex类型的参数. Integer::operator+=(c); m_i += ((const Complex&)c).m_i;//这里是重点,c有可能是const Integer&类型的 //所以强制转换,是可行的. } int m_i; }; int main(void){ Complex c1(1,2),c2(3,4); c1 += c2; cout << c1.m_r << '+' << c1.m_i << 'i' << endl; Integer& i1 = c1; // 4+6i; Integer& i2 = c2;//3+4i; i1+=i2;//i1调用子类Complex的拷贝赋值函数. cout << c1.m_r << '+' << c1.m_i << 'i' << endl;//7+10i; return 0; }
文章标题:c++中向上转型(安全)和向下转型(不安全)
转载来于:http://scyanting.com/article/ppsceo.html