C++--学习笔记013

攀登c++高峰

第三篇 第8章

STL 标准模板库

算法+容器+迭代器=STL

算法:algorithm

容器:container

迭代器:iterator

容器适配器:container adaptor

函数对象:functor

STL容器提供了这样的方便,它允许重复利用已有的实现,从而构造自己的特定类型下的数据结构。

STL包含很多计算机科学上的通用算法。

算法通过迭代器来定位和操控容器中的元素。如果没有迭代器,算法和容器就无法相互作用。

STL被组织在多个头文件和名字空间中,药想在程序中更简单使用STL,只需引入相应的头文件,使用对应的名字空间即可

函数模板---函数箱子

虽然算法处理的数据类型不同,但算法本身是相同的,这种情况就可以使用函数模板来简化工作,实现代码的复用。

函数模板的语法格式:

template <typename标识符>

返回值类型 函数名(形参表)

{

//函数体

}

例如:

//自定义的比较函数模板

//T就是函数模板的参数

template<typename T>

T mymax(const T a,const T b)

{

return a>b?a:b;

}

用typename定义的标识符就是函数模板中抽象的数据类型。我们可以使用抽象的数据类型作为模板来代替实际的数据类型。

int _tmain(int argc,_tchar* argv[])

{

//使用函数模板,比较整数

int na=2;

int nb=5;

wcout<<na<<"和”<<nb<<“中比较大的是”<<mymax(na,nb)<<endl;//动态生成模板函数int mymax(int,int)

//使用函数模板,比较浮点数

float fa=2.2;

float fb=5.5;

wcout<<fa<<"和"<<fb<<"中比较大的是"<<mymax(fa,fb)<<endl;//东戴生成模板函数float mymax(float,float)

return 0;

}

T->int

T->float

在调用模板函数的时候,编译器会根据调用模板函数的参数类型自动推导出模板函数的类型参数。

显式的调用模板函数的某个特定版本

//显示指明mymax()模板函数的类型参数是string类型,它将调用mymax()函数的string类型版本

string strmax=mymax<string>("chen","jia");

cout<<"较大的字符串是"<<strmax<<endl;

上面的结果是jia是较大的字符串,但我们不是要这个结果

以上这种情况,我们希望mymax()函数返回的是两个字符串中长度较长的字符串,这种情况就需要对模板函数进行特化,实现特定类型的模板函数。

//利用模板特化,实现特定类型的string的模板函数

template<>

string mymax<string>(const string a,const string b)

{

return a.length()>b.length()? a :b;

}

定义好上面这个函数模板之后,开始调用

//情况1:默认情况下,调用mymax<char*>版本

//比较字符串的字符,较大的字符串是“jia”

string strmax=mymax("chen","jia");

cout<<"使用普通版本,较大的字符串是"<<strmax<<endl;

//情况2:显示指明模板参数类型,调用模板特化后的mymax<string>版本

//比较字符串的长度,较长的字符串是“chen”

strmax= mymax<string>("chen","jia");

cout<<"使用模板特化版本,较长的字符串是"<<strmax<<endl;

类模板

类模板的语法格式

template <typename 标识符>

class 类名

{

//类的定义

}

时间: 2024-08-15 08:52:39

C++--学习笔记013的相关文章

【原】Java学习笔记013 - 阶段测试

1 package cn.temptation; 2 3 import java.util.Scanner; 4 5 public class Sample01 { 6 public static void main(String[] args) { 7 // 需求:编写程序打印如下效果:(杨辉三角变体) 8 // 1 9 // 1 1 10 // 1 2 1 11 // 1 3 3 1 12 // 1 4 6 4 1 13 // 1 5 10 10 5 1 14 15 // 思路:使用二维数组

网上图书商城项目学习笔记-013 添加购物车及我的购物车

一.流程分析 1.购物车模块 2.我的购物车分析 3.添加条目到购物车 二.代码 1.view层 (1)top.jsp 1 <a href="<c:url value='/CartItemServlet?method=myCart'/>" target="body">我的购物车</a> (2)desc.jsp 1 <form id="form1" action="<c:url value=

vector 学习笔记

vector 使用练习: /**************************************** * File Name: vector.cpp * Author: sky0917 * Created Time: 2014年04月27日 11:07:33 ****************************************/ #include <iostream> #include <vector> using namespace std; int main

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则 用了几天时间看了一下开源框架Caliburn.Micro 这是他源码的地址http://caliburnmicro.codeplex.com/ 文档也写的很详细,自己在看它的文档和代码时写了一些demo和笔记,还有它实现的原理记录一下 学习Caliburn.Micro要有MEF和MVVM的基础 先说一下他的命名规则和引导类 以后我会把Caliburn.Micro的 Actions IResult,IHandle ICondu

jQuery学习笔记(一):入门

jQuery学习笔记(一):入门 一.JQuery是什么 JQuery是什么?始终是萦绕在我心中的一个问题: 借鉴网上同学们的总结,可以从以下几个方面观察. 不使用JQuery时获取DOM文本的操作如下: 1 document.getElementById('info').value = 'Hello World!'; 使用JQuery时获取DOM文本操作如下: 1 $('#info').val('Hello World!'); 嗯,可以看出,使用JQuery的优势之一是可以使代码更加简练,使开

[原创]java WEB学习笔记93:Hibernate学习之路---Hibernate 缓存介绍,缓存级别,使用二级缓存的情况,二级缓存的架构集合缓存,二级缓存的并发策略,实现步骤,集合缓存,查询缓存,时间戳缓存

本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 -----------------------------------------------------------------------------------------------------------------

Activiti 学习笔记记录(三)

上一篇:Activiti 学习笔记记录(二) 导读:上一篇学习了bpmn 画图的常用图形标记.那如何用它们组成一个可用文件呢? 我们知道 bpmn 其实是一个xml 文件

HTML&CSS基础学习笔记8-预格式文本

<pre>标签的主要作用是预格式化文本.被包围在 pre 标签中的文本通常会保留空格和换行符.而文本也会呈现为等宽字体. <pre>标签的一个常见应用就是用来表示计算机的源代码.当然你也可以在你需要在网页中预显示格式时使用它. 会使你的文本换行的标签(例如<h>.<p>)绝不能包含在 <pre> 所定义的块里.尽管有些浏览器会把段落结束标签解释为简单地换行,但是这种行为在所有浏览器上并不都是一样的. 更多学习内容,就在码芽网http://www.

java/android 设计模式学习笔记(14)---外观模式

这篇博客来介绍外观模式(Facade Pattern),外观模式也称为门面模式,它在开发过程中运用频率非常高,尤其是第三方 SDK 基本很大概率都会使用外观模式.通过一个外观类使得整个子系统只有一个统一的高层的接口,这样能够降低用户的使用成本,也对用户屏蔽了很多实现细节.当然,在我们的开发过程中,外观模式也是我们封装 API 的常用手段,例如网络模块.ImageLoader 模块等.其实我们在开发过程中可能已经使用过很多次外观模式,只是没有从理论层面去了解它. 转载请注明出处:http://bl