C++8

C++8

1函数模板基本使用
1.1template < class / typename T> 告诉编译器紧跟的代码里出现T不要报错
1.2mySwap( T &a T &b ) 类型也需要传入 ,类型参数化
1.3myswap(a,b) 自动类型推导 按照a b的类型 来替换T
1.4myswap(a,b) 显示指定类型
2函数模板与普通函数的区别以及调用规则
2.1区别 普通函数可以进行隐式类型转换 模板不可以
2.2调用规则
2.2.1c++编译器优先考虑普通函数
2.2.2可以通过空模板实参列表的语法限定编译器只能通过模板匹配
2.2.3函数模板可以像普通函数那样可以被重载
2.2.4如果函数模板可以产生一个更好的匹配,那么选择模板
2.3模板的机制
2.3.1模板并不是万能的,不能通用所有的数据类型
2.3.2模板不能直接调用,生成后的模板函数才可以调用
2.3.3二次编译,第一次对模板进行编译,第二次对替换T类型后的代码进行二次编译
3模板局限性
3.1模板不能解决所有的类型
3.2如果出现不能解决的类型,可以通过第三地具体化来解决问题
3.3template<> 返回值 函数名<具体类型>(参数)
4类模板
4.1写法template <T…> 紧跟着是类
4.2与函数模板区别,可以有默认类型参数
4.3函数模板可以进行自动类型推导,而类模板不可以
4.4类模板中的成员函数 一开始不会创建出来,而是在运行时才去创建
5类模板做函数的参数
5.1三种方式
5.1.1显示指定类型
5.1.2参数模板化
5.1.3整体模板化
5.2查看类型名称
5.2.1cout << typeid(T).name() << endl;
6当类模板碰到继承
6.1基类如果是模板类,必须让子类告诉编译器 基类中的T到底是什么类型
6.2如果不告诉,那么无法分配内存,编译不过
6.3利用参数列表class Child :public Base
7类模板的类外实现成员函数
template <class T1, class T2>
7.1Person<T1, T2>::Person(T1 name, T2 age)
8类模板的分文件编写问题以及解决
8.1.h .cpp分别写声明和实现
8.2但是由于 类模板的成员函数运行阶段才去创建,导致包含.h头文件,不会创建函数的实现,无法解析外部命令
8.3解决方案 保护 .cpp文件 (不推荐)
8.4不要进行分文件编写,写到同一个文件中,进行声明和实现,后缀名改为.hpp
8.5约定俗成的
9类模板碰到友元函数
9.1友元函数类内实现
9.2friend void printPerson( Person<T1 ,T2> & p )
9.3友元函数类外实现
9.4friend void printPerson<>(Person<T1, T2> & p); //没有<>普通函数 声明 加上 <>模板函数声明
9.5让编译器看到 函数 并且看到这个Person类型
10

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值