首页 | IT新闻 | 硬件 | 操作系统 | 开发 | 网络编程 | 数据库 | 热门框架 | 网络安全 | 组网 | 建站指南 | 网页制作 | 特效 | 实用技巧 | 服务器 | 办公 | QQ | 探索 | 社区

  • 技术部落
  • 部落首页 > 程序开发 > C/C#/C++ > 正文
  • C++中的向上类型转换和向下类型转换
      2007-12-21  来源:雁南飞  编辑:Jsbulo  热度:

    在C++的世界中有这样两个概念,向上类型转换,向下类型转换,分别描述的是子类向基类和基类向子类的强制类型转换。

    向上强制类型转换

    切割:覆盖方法和子类数据丢失的现象生成切割(slice)。

    class Base
    {
    public:
    int b;
    virtual void Test()
    {
    cout << "base" <<endl;
    }
    };

    class Derived:public Base
    {
    public:
    int d;
    virtual void Test()
    {
    cout << "derived" <<endl;
    }
    };

    int main()
    {

    Derived d;
    Base b = d;//直接赋值(产生切割)
    b.Test();

    Base& b2 = d;//使用引用赋值(不产生切割)
    b2.Test();

    Base* b3 = &d;//使用指针赋值(不产生切割)
    b3->Test();

    return 1;
    }

    因此,我们得出结论,在向上强制转换过程中,使用指针和引用不会造成切割,而使用直接赋值会造成切割。

    向下强制类型转换

    使用dynamic_cast进行向下强制类型转换。使用此关键字有一下几个条件:

    1、必须有虚函数;
    2、必须打开编译器的RTTI开关(vc6: progect-> settings -> c/c++ tab ->category[c++ language]-> Enable RTTI);
    3.必须有继承关系。

    Base *b = new Derived;
    Derived *d = dynamic_cast<Derived*>(b);
    if(!d)
    {
    cout << "dynamic cast err!"<<endl;
    }
    else
    {
    d->Test();
    }

    本例子中,符合以上条件,转换成功。否则,会抛出std::bad_cast异常,转换返回NULL。

    因此,我们可以使用dynamic_cast来判断两个类是否存在继承关系。