1 昨日回顾
2 编译器对于模板的二次编译
写一个模板函数 然后进行调用
g++ template.cpp -o template
// 汇编
g++ -S template.cpp –o template.s
:set nu 打开vim行标
查看汇编代码:
20行mySwap<int>对应汇编语言36行的的mySwap
26行mySwap<char>对应汇编语言50行的mySwap
92行 mySwap<int>定义 (函数名加标签 就是这个函数的定义)
121行 mySwap<char>定义(函数名加标签 就是这个而函数的定义)
结论:
通过汇编我们可以看到编译器只给我们生成了int和char的模板函数的实现体
并没有生成全部类型的函数的实现体
第一次编译 C++编译器对模板函数 进行词法分析
如果语法分析没有任何问题 就可以继续执行
第二次编译 根据模板函数的调用来生成具体的摸板
而不是所有的数据类型都生成
通过编译器的第二次编译给我们生成两个模板函数的重载
3类模板的基本语法
4实现复数的模板类在一个文件中
实现+和-操作符重载:
<<输出操作符重写:
滥用友元函数:
案例中 这个函数本来是可以写在内部的,但是你非要写在外部,引发了一些问题:
举例:
在上面已经定义的Complex类下面定义了一个mysub方法,
声明了mysub是一个模板函数,
因为引用了类中私有变量,所以如果想引用它必须在类中声明
于是,在类中声明这个函数,
但是问题是mySub并没有被声明是模板函数 不能在后面加<T> 所以需要在代码最开始加模板函数声明
在代码最开始(即Complex类前面) 声明mySub为模板函数
但是这里还没有声明 模板类Complex 所以还需要在前面进行声明,
最终代码:
5实现复数类在多文件中
Complex.h:
改成hpp:
见到hpp说明是一个模板函数封装的 既可以
结论:
(hpp)
所以就不要拆了 直接写到类中。
6中午回顾
7类模板中的static
结论: a1 a2 a3指向同一个static变量
b1 b2 b3指向同一个static变量
8自定义的数组模板类-实现基本数据类型的封装
8自定义的数组模板类-实现基本数据类型的封装
9自定义数组模板类-实现自定义类型
https://github.com/eret9616/MyVector
结论: 如果想往<>容器中存放一个自定义类型的时候
一定要重写拷贝操作符和等号操作符 否则会有浅拷贝的风险。