C++中泛型编程与面向对象编程

1.  面向对象:封装(数据抽象)是基础,继承是手段,多态是目的;泛型编程:参数化类型(概念抽象)是基础,模板是手段,通用是目的
2.  面向对象是运行时问题空间的多态,泛型编程是编译时算法空间的多态
3.  OO以Type为中心,GP以Concept为中心,而Concept完全独立于Type;OO的type是显式定义的,type之间的关系也是显式定义的,是语言支持的 ;GP的Concept是由算法隐式定义的,Concept之间的关系,是无法用目前的C++语法直接表达的;Concept的Model完全可以是毫无关系的Type,refinement独立于inheritence,original concept与其refinement concept的model之间可以毫无关系
4.  以GP写就的算法,自动满足最小接口原则,无需为其参数定义形式化的类型;在OO中,这种形式化的Type具有的操作往往不是所有用到该Type的算法都会用到的
5.  OOP支持二进制组件形式的复用,GP支持源码层级的复用;与二进制码相比较,源码天生具有更多信息和更高级别,所以泛型编程支持更丰富的构件,但其代价是较弱的执行期动态性;你无法通过STL完成CORBA所能完成的功能,反之亦然,两种技术相互补充

——面向对象编程所依赖的多态性称为运行时多态性。
——泛型编程所依赖的多态称为编译时多态性或参数式多态性。

C++中多态分类:
 1)非参数化多态(Ad-hoc polymorphism):
  a)函数重载(Function Overloading)
  b)运算符重载(Operator Overloading)
2)参数化多态(Parametric polymorphism)
  c)模板(Template)
 
泛型编程的代表就是STL
下面的一个程序是结合了泛型编程与面向对象编程:

View Code
#include <iostream>
#include <vector>
#include <cstdlib>
using  namespace std;
class A{
     public:
    A(){
        cout<<endl;
        cout<< " ";
    }
     virtual ~A(){
        cout<< " ~A "<<endl;
    }
     virtual  void kind(){
        cout<< " Type-A "<<endl;
    }
};
class B: public A{
     public:
    B(){
        cout<< " ";
    }
     virtual ~B(){
        cout<< " ~B  ";
    }
     void kind(){
        cout<< " Type-B "<<endl;
    }
};
class C: public A{
     public:
    C(){
        cout<< " ";
    }
     virtual ~C(){
        cout<< " ~C  ";
    }
     void kind(){
        cout<< " Type-C "<<endl;
    }
};
class D: public A{
     public:
    D(){
        cout<< " ";
    }
     virtual ~D(){
        cout<< " ~D  ";
    }
     void kind(){
        cout<< " Type-D "<<endl;
    }
};
int main(){
     int n= 10;
    vector<A*> vec;
    A* pa;
     for( int i= 0;i<n;i++){
         int type=rand()% 4;
         switch(type){
             case  0:
                pa= new A();
                 break;
             case  1:
                pa= new B();
                 break;
             case  2:
                pa= new C();
                 break;
             case  3:
                pa= new D();
                 break;
        }
        vec.push_back(pa);
    }
    vector<A*>::iterator ite;
    cout<<endl;
     for(ite=vec.begin();ite!=vec.end();++ite)
        (*ite)->kind();
     for(ite=vec.begin();ite!=vec.end();++ite)
        delete (*ite);

     return  0;
}

输出如下:

参考:http://blog.csdn.net/wuliaoshengji/article/details/449870

转载于:https://www.cnblogs.com/xkfz007/archive/2012/07/16/2594174.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值