#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);
}