我的小小学习笔记(7)之C++------模板之模板函数
2017-11-02 22:50
453 查看
模板
模板是泛型编程的基础。所谓泛型编程就是编写与类型无关的逻辑代码,是一种复用的方式(但是跟复用不一样)(继承也是为了实现复用)。模板分为模板函数和模板类。
模板函数:
假设现在要实现一个比较两个数是否相等的重载函数。
比较int,支持=,但是string不支持(以前一个一个字符比,现在支持重载)
函数模板格式
template<class形参名1,class形参名2,...,class形参名n>
返回类型 函数名(参数列表)
{...}
模板形参定义可以用class,也可以用typename,含义相同
template<typenameT>
下面给出些例子感受一下。。。
(1)这个地方调用3个函数
(2)
没有模板函数实例化,不会生成对应的代码
基本格式还是会检查的,但是函数内部出问题不会检查出来。
看下一个程序
原因:bool ISEqual(const T&l,const T&r)//要把T推演成int,一个T既是int又是double,就出问题了
改正方法一:
cout << ISEqual(1, 1.2)<< endl;为假,T1推演成int,T2推演成double,int和double比较时会发生隐式类型的转化,l会转,当两个类型为相近类型时,范围小的会往范围大的转(char转向int,int转向unsigned
int,有符号向无符号转)。
改正方法二(1):
改正方法二(2):
(3)
调用谁呢?
模板是泛型编程的基础。所谓泛型编程就是编写与类型无关的逻辑代码,是一种复用的方式(但是跟复用不一样)(继承也是为了实现复用)。模板分为模板函数和模板类。
模板函数:
假设现在要实现一个比较两个数是否相等的重载函数。
比较int,支持=,但是string不支持(以前一个一个字符比,现在支持重载)
函数模板格式
template<class形参名1,class形参名2,...,class形参名n>
返回类型 函数名(参数列表)
{...}
模板形参定义可以用class,也可以用typename,含义相同
template<typenameT>
下面给出些例子感受一下。。。
(1)这个地方调用3个函数
#include <string> using namespace std; template<class T> bool ISEqual(T l, T r) { return l == r; } int main() { cout << ISEqual(1, 2) << endl;//int cout << ISEqual(string("11"), string("11")) << endl;//string cout << ISEqual('1', 'a') << endl;//char system("pause"); return 0; }
(2)
#define _CRT_SECURE_NO_WARNINGS 1 #include <iostream> #include <string> using namespace std; template<class T> bool ISEqual(T l, T r) { return l == r; } int main() { cout << ISEqual(1, 2) << endl;//int cout << ISEqual(string("11"), string("12")) << endl;//string cout << ISEqual('1', 'a') << endl;//char system("pause"); return 0; }
没有模板函数实例化,不会生成对应的代码
基本格式还是会检查的,但是函数内部出问题不会检查出来。
#define _CRT_SECURE_NO_WARNINGS 1 #include <iostream> #include <string> using namespace std; template<class T> bool ISEqual(const T& l,const T& r)//形参,用T时,尽量用const,不用,像string深拷贝传参,代价很大 { return l == r; } int main() { ISEqual(1, 2);//实参 //ISEqual(string("11"), string("12")); //ISEqual('1', 'a');//char system("pause"); return 0; }
看下一个程序
#define _CRT_SECURE_NO_WARNINGS 1 #include <iostream> #include <string> using namespace std; template<class T> bool ISEqual(const T& l,const T& r)//形参,用T时,尽量用const,不用,像string深拷贝传参,代价很大 { return l == r; } int main() { cout << ISEqual(1, 1) << endl; cout << ISEqual(1, 1.2) << endl; system("pause"); return 0; }
原因:bool ISEqual(const T&l,const T&r)//要把T推演成int,一个T既是int又是double,就出问题了
改正方法一:
#define _CRT_SECURE_NO_WARNINGS 1 #include <iostream> #include <string> using namespace std; template<class T> bool ISEqual(const T& l,const T& r) { return l == r; } template<class T1, class T2> bool ISEqual(const T1& l, const T2& r) { return l == r; } int main() { cout << ISEqual(1, 1) << endl; cout << ISEqual(1, 1.2)<< endl; system("pause"); return 0; }
cout << ISEqual(1, 1.2)<< endl;为假,T1推演成int,T2推演成double,int和double比较时会发生隐式类型的转化,l会转,当两个类型为相近类型时,范围小的会往范围大的转(char转向int,int转向unsigned
int,有符号向无符号转)。
改正方法二(1):
#define _CRT_SECURE_NO_WARNINGS 1 #include <iostream> #include <string> using namespace std; template<class T> bool ISEqual(const T& l,const T& r) { return l == r; } template<class T1, class T2> bool ISEqual(const T1& l, const T2& r) { return l == r; } int main() { cout << ISEqual(1, 1) << endl; //cout << ISEqual(1, 1.2)<< endl; //显示实例化,指定模板参数,就不会推演 cout << ISEqual<int,int>(1, 1.2) << endl; system("pause"); return 0; }
改正方法二(2):
#define _CRT_SECURE_NO_WARNINGS 1 #include <i 4000 ostream> #include <string> using namespace std; template<class T> bool ISEqual(const T& l,const T& r) { return l == r; } //template<class T1, class T2> //bool ISEqual(const T1& l, const T2& r) //{ // return l == r; //} int main() { cout << ISEqual(1, 1) << endl; //cout << ISEqual(1, 1.2)<< endl; //显示实例化,指定模板参数,就不会推演 cout << ISEqual<int>(1, 1.2) << endl; system("pause"); return 0; }
(3)
#define _CRT_SECURE_NO_WARNINGS 1 #include <iostream> #include <string> using namespace std; template<class T> bool ISEqual(const T& l, const T& r) { return l == r; } //template<class T1, class T2> //bool ISEqual(const T1& l, const T2& r) //{ // return l == r; //} int main() { cout << ISEqual(1, 1) << endl; //cout << ISEqual(1, 1.2)<< endl; //显示实例化,指定模板参数,就不会推演 cout << ISEqual<int>(1, 1.2) << endl; cout << ISEqual<double>(1, 1.2) << endl; system("pause"); return 0; }
调用谁呢?
#define _CRT_SECURE_NO_WARNINGS 1 #include <iostream> #include <string> using namespace std; template<class T> bool ISEqual(const T& l, const T& r) { return l == r; } bool ISEqual(int l,int r) { return l == r; } int main() { cout << ISEqual(1, 2) << endl; ISEqual(string("11"), string("11")); system("pause"); return 0; }
相关文章推荐
- C++学习笔记--函数模板
- 设计模式C++学习笔记之九(Template Method模板方法模式)
- c++学习笔记(16.STL模板库简介)
- C++菜鸟学习笔记——模板与泛型编程
- 《C++ Primer Plus》14.4 类模板 学习笔记
- C++学习笔记24 函数模板
- C++学习笔记 -- 循环队列的模板
- C++学习笔记之由文本文件读取数据到vector模板建立的二维数组 并存储为新的文本文件
- 我的小小学习笔记(5)之C++-----缺省函数
- C++ primer第二次阅读学习笔记(第16章:模板与泛型编程) .
- c++模板 学习笔记
- 金庸小说考试之模板方法模式学习笔记[C++版]
- [置顶]C++学习笔记之模板篇
- C++学习笔记57——非类型模板形参与泛型代码原则
- 嵌入式开发之C++基础学习笔记5--静态成员,友元,运算符重载,模板,文件流
- c++ 模板学习笔记:理解类模板的特化与偏特化(权哥)
- c++学习笔记(十六):函数模板
- C++学习笔记--模板
- C++学习笔记25 类模板的特化
- C++学习笔记-模板