STL静多态和动多态小释

博客介绍了C++中用多态实现的注意事项,包括定义抽象类、剥离业务到公共类、子类实现接口函数等,还提到使用时参数传递及虚表开销问题。同时展示了模板演绎实参的使用,如ShowDemo、EffecEach、ShowDemoAll等模板函数,并给出了相应代码示例。

#include <iostream>
#include <vector>
using namespace std;
/*用多态来实现的话需要
<1>定义时注意:
1.定义
class Base
{

 virtual ShowDemo() const = 0;
};
2.剥离抽象业务放到公共类中
3.让 Derived1, Derived2都从Base 继承而来
4.子类必须实现接口函数
<2>使用时注意
1.处理业务函数的参数只能使用 Base& 或者 Base* 方式传递对象地址,
  让其在运行期判别类型找到对应函数
2.每次继承增加一张虚表增加资源开销。
*/
class Derived1
{
public:
 void ShowDemo() const { cout<<"Derived1::ShowDemo()"<<endl; }
};

class Derived2
{
public:
 void ShowDemo() const { cout<<"Derived2::ShowDemo()"<<endl; }
};

//使用模板演绎实参,直接在运行期就得到确定的对象类型
//只不过使用泛型,少了对ShowDemo做重载,但其实实例化了两次
//因为仅仅针对于这一整类使用泛型可以,但是如果传入的T为其他类型呢
//静态检测会发现问题,发现结构无此函数
template< typename T >
void ShowDemo( T const& t_g )
{
 t_g.ShowDemo();
}

template< typename T1, typename T2 >
void EffecEach( T1 const& t_g_1, T2 const& t_g_2 )
{
 t_g_1.ShowDemo();
 t_g_2.ShowDemo();
}

template < typename T >
void ShowDemoAll( vector<T> const& t_v_g )
{
 for( int i = 0; i < t_v_g.size(); i++ )
  t_v_g[i].ShowDemo(); //
}


void main()
{

 Derived1 t_d_1;
 Derived2 t_d_2;

 ShowDemo(t_d_2);
 ShowDemo(t_d_1);

 EffecEach( t_d_1, t_d_2 );
 vector<Derived2> coll;
 coll.push_back(t_d_2);
 ShowDemoAll(coll);
}


 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值