1.随意输入两个数x和y,输出最大值max。

int max(int x, int y)

{return x>y?

x:y;}

2.函数模版

(1)用一种或者多种通用类型去表示函数——函数模版。

(2)函数模版因为没有详细的数据类型。所以函数模版不可执行。

(3)作用:模板就是实现代码重用机制的一种工具,它能够实现类型參数化,即把类型定义为參数, 从而实现了真正的代码可重用性。模版能够分为两类,一个是函数模版。另外一个是类模版。

注:函数模版在调用时必须用详细的类型来替代,使之转换为一个详细函数。

3.函数模版的定义:

template <class T>

A.模版定义的关键词:template

<class T>用来说明一个通用类型T。

B.class T仅仅用来表示一种类型,也能够表示多个通用类型:

<class T1, class T2, class T3, ..., class Tn>

4.函数模版的调用

(1)将函数模版作为一个函数调用。

(2)系统将自己主动依照调用表达式实參的类型来替代函数模版中的通用类型,使之转化为一个详细函数然后运行。

example 1



#include <iostream.h>



template <class T>

T max(T x, T y)

{return x>y?

x:y;}

int main()

{

    int x = 3, y = 4;

    double d1 = 2.3, d2 = 3.4;

    long l1 = 32L, l2 = 35L;

    cout<<max(x, y)<<endl;

    cout<<max(d1, d2)<<endl;

    cout<<max(l1, l2)<<endl;

}

程序输出:

4

3.4

35

分析:因为实參x,y为int类型,系统自己主动将模版中的类型T用int来替代。

函数转化:int max(int x, int y) {return x>y?

:x:y;}



example 2



#include <iostream.h>



template <class T>

void exchange(T &x, T &y, T &z)

{

    T t;

    if(x>y) {t = x; x = y; y = z;}

    if(x>z) {t = x; x = z; z = t;}

    if(y>z) {t = y; y = z; z = t;}

}

5.函数模版的重载

(1)函数模版同意隐性类型转换。

(2)函数模版重载时不同意重载为一个模版——函数模版的重载仅仅能够是一个详细的显性函数。

(3)函数模版的重载仅仅能够在函数模版不可调用时,系统将自己主动的通过隐式类型转换后调用函数模版时重载。

example 3



#include <iostream.h>



template <class T>

T max(T x, T y)

{

    cout<<"This is T max()."<<endl;

    return x>y?x:y;

}

double max(int x, double y)

{

    cout<<"This is double max()."<<endl;

    return x>y?

x:y;

}

int main()

{

    int x1 = 2, x2 = 3;

    double d1 = 2.3, d2 = 3.4;

    long l1 = 3L, l2 = 5L;

    cout<<max(x1, x2)<<endl; //调模版

    cout<<max(l1, l2)<<endl; //调模版

    cout<<max(x1, l2)<<endl; //调重载

    cout<<max(x1, d2)<<endl; //调重载

    cout<<max(d1, d2)<<endl; //调模版

}

程序输出:

This is T max().

3

This is T max().

5

This is double max().

5

This is double max().

3.4

This is double max().

3.4

模版的重载仅仅可以有一个详细的函数。

6.类模版

template <class T>

class Tany

{

    T x, y;

public:

    Tany(T xx, T yy):x(xx),y(yy) {}

    T getx() {return x;}

    T gety() {return y;}

};

类模板的详细化实现:

(1)通过类模板创建对象时由详细类型替代模版类型。

(2)类模版对象的定义

类名<详细类型>对象名(初始化列表)

若有多个通用类型必须表示多个详细类型

比如:Tany <int> objint(3, 4);

      Tany <double> objdouble(3.4, 5.6);

C++语言笔记系列之二十——模版的更多相关文章

  1. Java 设计模式系列(二十)状态模式

    Java 设计模式系列(二十)状态模式 状态模式,又称状态对象模式(Pattern of Objects for States),状态模式是对象的行为模式.状态模式允许一个对象在其内部状态改变的时候改 ...

  2. 《sed的流艺术之四》-linux命令五分钟系列之二十四

    本原创文章属于<Linux大棚>博客,博客地址为http://roclinux.cn.文章作者为rocrocket. 为了防止某些网站的恶性转载,特在每篇文章前加入此信息,还望读者体谅. ...

  3. 《sed的流艺术之二》-linux命令五分钟系列之二十二

    本原创文章属于<Linux大棚>博客,博客地址为http://roclinux.cn.文章作者为rocrocket. 为了防止某些网站的恶性转载,特在每篇文章前加入此信息,还望读者体谅. ...

  4. WebService学习笔记系列(二)

    soap(简单对象访问协议),它是在http基础之上传递xml格式数据的协议.soap协议分为两个版本,soap1.1和soap1.2. 在学习webservice时我们有一个必备工具叫做tcpmon ...

  5. ComicEnhancerPro 系列教程二十:用“文件比较”看有损、无损

    作者:马健邮箱:stronghorse_mj@hotmail.com 主页:http://www.comicer.com/stronghorse/ 发布:2017.07.23 教程二十:用“文件比较” ...

  6. C++语言笔记系列之十二——C++的继承

    C++的继承 1.继承方式 public(公有继承) 派生类中的成员能够訪问基类的public成员和protected成员,但不能訪问基类的private成员. 派生类的对象仅仅能訪问基类的publi ...

  7. Go语言核心36讲(Go语言实战与应用二十二)--学习笔记

    44 | 使用os包中的API (上) 我们今天要讲的是os代码包中的 API.这个代码包可以让我们拥有操控计算机操作系统的能力. 前导内容:os 包中的 API 这个代码包提供的都是平台不相关的 A ...

  8. Go语言核心36讲(Go语言实战与应用二十四)--学习笔记

    46 | 访问网络服务 前导内容:socket 与 IPC 人们常常会使用 Go 语言去编写网络程序(当然了,这方面也是 Go 语言最为擅长的事情).说到网络编程,我们就不得不提及 socket. s ...

  9. Go语言核心36讲(Go语言实战与应用二十六)--学习笔记

    48 | 程序性能分析基础(上) 作为拾遗的部分,今天我们来讲讲与 Go 程序性能分析有关的基础知识. Go 语言为程序开发者们提供了丰富的性能分析 API,和非常好用的标准工具.这些 API 主要存 ...

随机推荐

  1. ios之UITableView

    今天要分享的是IOS开发中一个使用率非常高的一个控件-------UITableView,这两天正在使用tableview做信息的显示,在写代码时对tableview和tableviewcell的几种 ...

  2. sin_addr.s_addr和sin_addr.S_un.S_addr

    sin_addr.s_addr和sin_addr.S_un.S_addr 先mark一下,等下写

  3. 自动化测试如何解析excel文件?

    前言 自动化测试中我们存放数据无非是使用文件或者数据库,那么文件可以是csv,xlsx,xml,甚至是txt文件,通常excel文件往往是我们的首选,无论是编写测试用例还是存放测试数据,excel都是 ...

  4. IDEA中远程Debug调试

    一.设置JVM支持远程Debug调式 由于我的应用是springboot, 所以直接使用java -jar的方法将服务启动起来. java -Xdebug -Xrunjdwp:transport=dt ...

  5. 杭电 5326 Work (并查集求子结点为k的结点数)

    Description It’s an interesting experience to move from ICPC to work, end my college life and start ...

  6. [NOI2001] 炮兵阵地 (状压Dp经典例题)

    如果您的电脑比较优秀能在 1sec 内跑过 2^1000 的时间复杂度,不妨你可以尝试一下,其实实际时间复杂度远远少于 2^1000,作为骗分不错的选择QAQ,然后我们来分析一下正解: 很显然此题是一 ...

  7. ExtJS前端框架EXT弹出窗口事件

    https://blog.csdn.net/alsyuan/article/details/73240841 Ext.MessageBox.alert()Ext.MessageBox.alert()提 ...

  8. Java并发编程:自己动手写一把可重入锁

    关于线程安全的例子,我前面的文章Java并发编程:线程安全和ThreadLocal里面提到了,简而言之就是多个线程在同时访问或修改公共资源的时候,由于不同线程抢占公共资源而导致的结果不确定性,就是在并 ...

  9. [NOIP2000] 提高组 洛谷P1018 乘积最大

    题目描述 今年是国际数学联盟确定的“2000――世界数学年”,又恰逢我国著名数学家华罗庚先生诞辰90周年.在华罗庚先生的家乡江苏金坛,组织了一场别开生面的数学智力竞赛的活动,你的一个好朋友XZ也有幸得 ...

  10. 【ZJOI2017 Round1练习&BZOJ4767】D1T3 两双手(排列组合,DP)

    题意: 100%的数据:|Ax|,|Ay|,|Bx|,|By| <= 500, 0 <= n,Ex,Ey <= 500 思路:听说这是一道原题 只能往右或者下走一步且有禁止点的简化版 ...