【C++】非类型模板参数、模板特化,View的这些基础知识你必须要知道

因此收集整理了一份《2024年最新网络安全全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上网络安全知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip204888 (备注网络安全)
img

正文
Date d2(2023, 1, 9);
cout << Less(d1, d2) << endl;

Date* p1 = &d1;
Date* p2 = &d2;
cout << Less(p1, p2) << endl;
return 0;

}


![image-20230110135553319](https://img-blog.csdnimg.cn/img_convert/2963c8ae3246176ed7b051e37efe4374.png)


所以我们要去对Date\*进行特殊化处理——Date\*


函数模板的特化步骤:


1. **必须要先有一个基础的函数模板**
2. **关键字template后面接一对空的尖括号<>**
3. **函数名后跟一对尖括号,尖括号中指定需要特化的类型**
4. **函数形参表: 必须要和模板函数的基础参数类型完全相同,如果不同编译器可能会报一些奇怪的错误**




//针对某些类型进行特殊处理——Date*
template<>
bool Less<Date*>(Date* left, Date* right)
{
return *left < *right;
}


函数模板也可以不写成模板,直接写成函数也是可以的,因为函数模板支持重载


#### 2.类模板特化


1.**全特化**


全特化即是将模板参数列表中所有的参数都确定化


类模板的全特化将模板参数列表中的所有参数我们都将其写出来:


![image-20230110142030654](https://img-blog.csdnimg.cn/img_convert/76050b02f5da5549b5fd5b319eead77c.png)


如果此时的数据类型是我们自己定义的,比如我们之前所说的**Date**\*之时,比较的是地址,所以我们之前是通过自己写一个仿函数来实现比较大小的,代码如下:




struct PDateLess
{
bool operator()(const Date* d1, const Date* d2)
{
return *d1 < *d2;
}
};

struct PDateGreater
{
bool operator()(const Date* d1, const Date* d2)
{
return d1>d2;
}
};
void TestPriorityQueue()
{
//大堆
priority_queue <Date
, vector<Date
>, PDateLess> q3;
q3.push(new Date(2018, 10, 29));
q3.push(new Date(2018, 10, 28));
q3.push(new Date(2018, 10, 30));
cout << q3.top() << endl;
//小堆
priority_queue<Date
, vector<Date*>, PDateGreater> q4;
q4.push(new Date(2018, 10, 29));
q4.push(new Date(2018, 10, 28));
q4.push(new Date(2018, 10, 30));
cout << *q4.top() << endl;
}


现在,我们如果不写仿函数,这时候就可以通过针对Date\*实现特化了:




template
class Greater
{
public:
bool operator()(const T& x, const T& y) const
{
return x > y;
}
};
//特化
template<>
class Greater<Date*>
{
public:
bool operator()(Date* const& d1, Date* const& d2) const
{
return d1 > d2;
}
};
int main()
{
hwc::priority_queue<Date
, vector<Date
>, Greater<Date*>> q4;
q4.push(new Date(2018, 10, 29));
q4.push(new Date(2018, 10, 28));
q4.push(new Date(2018, 10, 30));
cout << *q4.top() << endl;
return 0;
}


**2.偏特化**


偏特化:任何针对模版参数进一步进行条件限制设计的特化版本。部分特化将模板参数类表中的一部分参数特化 :




template<class T1,class T2>
class Data
{
public:
Data()
{
cout << “Data<T1,T2>” << endl;
}
private:
T1 _d1;
T2 _d2;
};
//半特化、偏特化
template
class Data<T1, char>
{
public:
Data()
{
cout << “Data<T1,char>” << endl;
}
};
int main()
{
//模板
Data<int,int>d;
//偏特化
Data<double,char> d1;
Data<char,char> d2;
return 0;
}


偏特化可以对参数进一步的限制:只要是指针,不管是什么类型的指针,针对指针,也可以针对引用:




//参数类型进一步限制
template<class T1,class T2>
class Data<T1*, T2*>
{
public:
Data()
{
cout << “Data<T1*,T2*>” << endl;
}
};

template<class T1,class T2>
class Data<T1&, T2&>
{
public:
Data()
{
cout << “Data<T1&,T2&>” << endl;
}
};

int main()
{

return 0;

}
int main()
{
//指针
Data<char*, char*> d5;
Data<double*, int*> d6;

//引用
Data<double&,int&> d7;
return 0;

}


特化的本质体现的是编译器的参数匹配原则




---


### 三、模板的分离编译


模板的分离编译我们之前就有说过,这里重新说一遍:


分离编译:一个程序(项目)由若干个源文件共同实现,而每个源文件单独编译生成目标文件,最后将所有目标文件链接起来形成单一的可执行文件的过程称为分离编译模式。


而对于模板,链接之前并不会交互,分离编译就会导致用的地方.cpp没有实例化,没有实例化就会导致链接不上。


比如:a.h,a.cpp,test.cpp这三个文件,


编译链接过程:预处理——>编译——>汇编——>链接


预处理:去注释,宏替换,头文件展开,条件编译(a.i,test.i)


编译:生成汇编代码(a.s,test.s)、符号汇总


汇编:把汇编变成二进制目标文件(a.o,test.o),形成符号表


链接:符号表的合并与重定位,将多个obj文件合并成一个,形成可执行程序


![image-20230110191314742](https://img-blog.csdnimg.cn/img_convert/c336b7c846b1a16c32f3e297b22a339e.png)


解决方案:


1. 将声明和定义放到一个文件 **“xxx.hpp”** 里面或者**xxx.h**其实也是可以的。推荐使用这种。此时在编译阶段中,就有了模板的实例化。
2. 模板定义的位置显式实例化。这种方法不实用,不推荐使用 。如果实例化的类型少那还是可行的,如果要针对的类型很多,那就太麻烦了
3. ![image-20230110193321200](https://img-blog.csdnimg.cn/img_convert/6bb86fb853e2e0f0a7ef787ae6994b5e.png)

## 最后

**自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。**

**深知大多数网络安全工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!**

**因此收集整理了一份《2024年网络安全全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。**

![img](https://img-blog.csdnimg.cn/img_convert/7f5f2b36710de7c1e2c70883dcd18606.png)

![img](https://img-blog.csdnimg.cn/img_convert/7575fb36156e5fa9de7dabcf54049ab3.png)

![img](https://img-blog.csdnimg.cn/img_convert/1067b600a26962e7ed980d3a83da2a73.png)

![img](https://img-blog.csdnimg.cn/img_convert/aca8331eb8ad14074bf0f8956d3702d2.png)

![img](https://img-blog.csdnimg.cn/img_convert/a87560d24a387ed38dd64ee30a8775e1.png)

 

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上网络安全知识点!真正的体系化!**

[**如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!**](https://bbs.csdn.net/topics/618653875)

**由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!**

g-AjG2XKlp-1715564480302)]

[外链图片转存中...(img-O6PrNLPT-1715564480302)]

[外链图片转存中...(img-TVLk8DER-1715564480302)]

 

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上网络安全知识点!真正的体系化!**

[**如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!**](https://bbs.csdn.net/topics/618653875)

**由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值