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. p1036 选数(不详细勿看,递归)

    题目:传送门 这题,不会做,而且看了好久才看懂题解的,然后在题解的基础上补了一个 if(start>end) return 0 感觉这样对于我更直观 转载自:大神博客的传送门,点击进入 先声明, ...

  2. POJ-3190-分配畜栏

    这个题首先,我们需要注意的是它的时间是一秒,其中还包括了你读入数据的时间,因为cin我写的时候没有解除绑定,所以直接超时,我们直接用scanf函数读入50000组数据好了. 然后就是poj交的时候,如 ...

  3. Firefox--摄像头麦克风权限

    在自动化测试的过程中,可能会遇到来自浏览器的权限提示(摄像头.麦克风),今天,就讨论一下如何结局这个问题. 先来认识一下来自Firefox的权限提示,访问一个需要摄像头或者麦克风的网站 你可能觉得,一 ...

  4. SpringMVC的删除功能

    Dao层 package net.roseindia.dao; import java.util.Date; import java.util.List; import net.roseindia.m ...

  5. tiles框架的definition讲解

    <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE tiles-definitions PUBL ...

  6. POJ3528移石头

    题目大意: 河道两旁直线上有两块石头不能移动,距离为L,但中间放置了N块石头并列出这N块石头到起点的距离,可以移走M块,那么移走石头后每次牛跨石头的最小距离如何达到最大值,输出这个最大值 让最小距离的 ...

  7. 【模板】prim的heap优化

    简单的代码.. 时间复杂度为O((n + m)logn) 大部分情况下还是跑不过kruskal的,慎用. #include <cstdio> #include <queue> ...

  8. CodeForces - 586D Phillip and Trains

    这道题是一道搜索题 但是 如果没有读懂或者 或者拐过弯 就很麻烦 最多26个火车 那么每一个周期 (人走一次 车走一次) 就要更改地图 的状态 而且操作复杂 容易超时 出错 利用相对运动 计周期为 人 ...

  9. resin web项目的 编码问题

    问题描述: 服务器迁移,迁移以后Linux系统编码由 UTF-8 变成了GBK !!! 导致在resin 中运行java web项目,调用 http 接口,解析http 接口的返回内容 如:xml 时 ...

  10. mongodb 报错问题

    系统不支持:Mongo 错误位置 FILE: C:\wamp64\www\frame\a_tp32\ThinkPHP\Library\Think\Db\Driver\Mongo.class.php L ...