初步C++类模板学习笔记

初步C++类模板学习笔记

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

类模板

 

实现:在上课时间的定义给它的一个或多个参数,这些参数代表了不同的数据类型。                              –>抽象的类。

在调用类模板时, 指定參数, 由编译系统依据參数提供的数据类型自己主动产生对应的模板类                   –>详细的类。

 

 

 

类模板的定义

C++的类模板的写法例如以下:

 

template <类型參数表>        //类型參数表的写法就是:class 类型參数1, class 类型參数2, …
class 类模板名
{
    成员函数和成员变量
};

 

类模板里的成员函数, 如在类模板外面定义时,

 

template <型參数表>
返回值类型 类模板名<类型參数名列表>::成员函数名(參数表)
{ 
    ……
}

 

用类模板定义对象的写法例如以下:
类模板名 <真实类型參数表>  对象名(构造函数实际參数表);
假设类模板有无參构造函数, 那么也能够仅仅写:
类模板名 <真实类型參数表>  对象名;

 

 

举例:

 

template <class T1, class T2>
class Pair{
public:
    T1 key;  //keyword
    T2 value;  //值
    Pair(T1 k,T2 v):key(k),value(v) { };
    bool operator < (const Pair<T1,T2> & p) const; 
};

template<class T1,class T2>    //在类外定义 Pair的成员函数 operator <
bool Pair<T1,T2>::operator<( const Pair<T1, T2> & p) const 
{ return key < p.key; }  

Pair类模板的使用:

 

int main()
{
    Pair<string, int> student("Tom",19); 
    //实例化出一个类 Pair<string, int>
    cout << student.key << " " << student.value; 
    return 0;

}

 

 

函数模版作为类模板成员

 

 

#include <iostream>
using namespace std;
template <class T>
class A{
public:
    template<class T2> 
    void Func(T2 t) { cout << t; } //成员函数模板
};
int main(){
    A<int> a;
    a.Func('K'); //成员函数模板 Func被实例化
     return 0;
}

 

类模板与非类型參数

 

 

template <class T, int size>
class CArray{
    T array[size];
public:
    void Print( ) 
    {
        for(int i = 0; i < size; ++i)
        cout << array[i] << endl; 
    }       
};

 

CArray<double, 40> a2;
CArray<int, 50> a3;

注意:
CArray<int,40>和CArray<int,50>全然是两个类
这两个类的对象之间不能互相赋值

 

 

 

类模板与继承

 

 

普通类从模板类派生

 

template <class T>
class A { T v1;  int n; };
class B:public A<int> { double v;  };// 类A是个类模板。A<int>是模板类
int main() { 
    B obj1; 
    return 0;
}

 

类模板从模板类派生

 

template <class T1, class T2>
class A { T1 v1; T2 v2;    };


template <class T>
class B:public  A<int, double> { T v; };
int main() {

     B<char> obj1; return 0;

 }

 

类模板A   ->实例化  模板类A<int,double>  ->派生   类模板B   ->实例化  模板类B<char>

此时B中有成员

        int v1;

        double  v2;

        T v;

 

 

 

 

类模板从普通类派生

 

 

class A {  int v1; };


template <class T>
class B:public A  { T v; };
int main() { 
    B<char> obj1; 
    return 0; 
}

没什么可说的。在继承A的基础上添加了T类型的成员。

 

 

类模板从类模板派生

 

#include <iostream>
using namespace std;
template <class T1, class T2>
class A
{
public:
    T1 v1; T2 v2;
};

template <class T1, class T2>
class B:public A<T1,T2>
{
public:
    T1 v3; T2 v4;
};

int main()
{
    B<int,double> b;
    B<int,double> *pb = &b;
    b.v1 = 1;
    b.v3 = 3;
    b.v2 = 2.2;
    b.v4 = 4.4;
    cout << pb->v1<<endl;
    cout << pb->v2<<endl;
    cout << pb->v3<<endl;
    cout << pb->v4<<endl;

    return 0;
}

要保证当给类模板B实例化的时候。类模板A也随之完毕类型T的实例化。

B<int,double> b 时,B有自身的成员int v3 、double v4 也有继承A<int,double>的成员int v1 和 double v2

 

 

 

 

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117786.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • MFC消息_为什么发消息对方不回

    MFC消息_为什么发消息对方不回由arain于星期二,11/02/2010-10:44发表MSGmessage;  if(::PeekMessage(&message,NULL,0,0,PM_REMOVE)){      ::TranslateMessage(&message); //把键盘消息翻译成字符消息      ::DispatchMessage(&message

    2022年9月12日
    2
  • Anchorpoint_the mythology handbook

    Anchorpoint_the mythology handbook之前做一个imageview的transform的动画,从scale(1,1)变成scale(0.3)

    2022年10月8日
    3
  • Android—Gradle教程(一)「建议收藏」

    Android—Gradle教程(一)「建议收藏」前言在前几篇中,讲解了Groovy的基础语法,学习新语法过程总是枯燥的,但为了更好的掌握Gradle,那就必须经过该过程。当然从这一篇将会从零基础开始,开展对Gradle的讲解。1.掌握Gradle基础1.1环境配置去官网下载gradle或者从本地用户文件夹下的.gradle/wrapper/dists找到本地缓存的gradle开发工具包(注意带bin文件夹的这个grade-x.x)系统属性配置:添加GRADLE_HOME:C:\Users\sheji.gradle\wrapper\

    2022年6月28日
    33
  • 【备忘录】麦克斯韦速率分布

    【备忘录】麦克斯韦速率分布突然想做麦克斯韦速度分布的复习,找到了以前读《新概念物理学·热学》的笔记发现高中时我如何臆测不得其解的东西竟然被这一页提纲挈领的笔记就解释很清楚了如果让我给高中时的我带话帮助他迅速理解这

    2022年7月4日
    23
  • 随笔

    随笔

    2021年8月21日
    64
  • webstorm 激活码【中文破解版】

    (webstorm 激活码)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

    2022年3月21日
    54

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号