zoukankan      html  css  js  c++  java
  • c++ 多态性

    c++支持多态性的几种方式:
    1、通过一个隐式转化,从“派生类指针或引用”转化到“其公有基类类型的指针或引用”
    Query *pquery = new NameQuery( "Glass" );
    2、通过虚拟函数机制
    3、通过dynamic_cast 和 typeid 操作符(RTTI)
    1)首先这两个操作符是在“运行时刻类型识别”!
    2)当一个类库是由第三方库提供商提供时,此时我们不能增加虚拟成员函数。但我们可能仍然希望扩展这个类库(以便增加类库的功能),这种情况下,就必须使用dynamic_cast。


    使用dynamic_cast时注意:
    如果转化的类型为派生类指针,这样使用:
    void Company::payroll( employee *pe )
    {
      if( programmer *pm = dynamic_cast< programmer * >( pe ))
      {
        //使用pm
      }
      else
      {
        //使用employee的成员函数
      }
    }

    如果转化的类型为派生类引用,这样使用:
    #include <typeinfo>
    void Company::payroll( employee &pe )
    {
      try
      {
        programmer &pm = dynamic_cast< programmer & >( pe );
        //使用pm
      }
      catch( std::bad_cast )
      {
        //使用employee的成员函数
      }
    }


    使用typeid时:
    当typeid的操作数为“类类型”,但不是带有虚拟函数的类类型时,typeid操作符会指出当前操作数的类型:
    例如:
    class Base{/*没有虚拟函数*/};
    class UserBase : public Base {};
    UserBase user;
    Base *pb = &user;
    typeid(*pb).name()的值为Base//如果基类中有虚拟函数,则结果为UserBase

    Base &rb = user;
    typeid(rb).name()的值为Base//如果基类中有虚拟函数,则结果为UserBase

    当typeid的操作数为“类型指针时”返回的结果是操作数的类型,例如:
    typeid(&rb).name()的值为Base *
    typeid(pb).name()的值为Base *
  • 相关阅读:
    RabbitMQ之六种队列模式
    面试资料
    位掩码的介绍与使用(小白鼠试毒问题)
    递归函数的写法(以strcpy函数为例)
    查找算法简介及实现
    八大排序算法概述及实现
    快速排序算法(一)
    最大(小)堆和堆排序简介
    满二叉树各种节点数目的计算
    LPSTR、LPCSTR、LPWSTR、LPCWSTR、LPTSTR、LPCTSTR的来源及意义
  • 原文地址:https://www.cnblogs.com/handongdong/p/2223777.html
Copyright © 2011-2022 走看看