STL traits

2024-02-22 13:28
文章标签 stl traits

本文主要是介绍STL traits,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

定义

我将从定义、技术实现、设问形式、实例总结来阐述我对于萃取机制的理解。

1.定义:traits中文意思是特性,它通过提取不同类的共性,使得可以统一处理。

2.技术实现:traits运用显式模板特殊化将代码中因为类型不同而发生变化的片段提取出来,用统一的接口来包装,并通过traits模板类公开的接口间接访问相应的类。

3.设问形式:

问题1:什么是显式模板特殊化呢?

答:模板特殊化又分了一个偏特化(意思就是没有完全的特化)我们来看一段代码,

复制代码
template<class T,class U>
//基础模板类
class NumTraits
{};
//模板特化的格式
template //偏特殊化
class NumTraits
{
public:
typedef int resulttype;
typedef int inputargtype;
};
template
class NumTraits
{};
//模板特化的格式
template<> //特殊化
class NumTraits
{
public:
typedef int resulttype;
typedef int inputargtype;
};
复制代码

问题2:用实例来展示一下为什么会使用萃取机制?

答:我会用(3步走)的代码来解释为什么需要使用萃取。

复制代码
#include
using namespace std;

//①基本类写法
class IntArray
{
public:
IntArray()
{
a = new int[10];
for (int i = 0; i < 10; ++i)
{
a[i] = i + 1;
}
}
~IntArray()
{
delete[] a;
}

int GetSum(int times)
{int sum = 0;for (int i = 0; i < 10; ++i)sum += a[i];cout << "int sum=" << sum << endl;return sum * times;
}

private:
int a;
};
class FloatArray
{
public:
FloatArray()
{
f = new float[10];
for (int i = 1; i <= 10; ++i)
{
f[i - 1] = 1.0f / i;
}
}
~FloatArray()
{
delete[] f;
}
float GetSum(float times)
{
float sum = 0.0f;
for (int i = 0; i < 10; i++)
sum += f[i];
cout << “float sum=” << sum << endl;
return sum * times;
}
private:
float
f;
};
//②模板写法
template
class Apply
{
public:
float GetSum(T& t, float inarg)
{
return t.GetSum(inarg);
}
};

//以上方法不能完全解决我们的问题(函数返回值固定,就会导致异常)
//③采用萃取机制:模板特化
template
class NumTraits
{};
//模板特化的格式
template<>
class NumTraits
{
public:
typedef int resulttype;
typedef int inputargtype;
};
template<>
class NumTraits
{
public:
typedef float resulttype;
typedef float inputargtype;
};
template
class Apply2
{
public:
NumTraits::resulttype GetSum(T& obj, NumTraits::inputargtype inputarg)
{
return obj.GetSum(inputarg);
}
};
int main()
{
IntArray intary;
FloatArray floatary;
Apply ai; //采用模板
Apply af; //采用模板
cout << “1整型数组的和3倍:” << ai.GetSum(intary, 3) << endl;
cout << “1浮点数组的和3.2倍:” << af.GetSum(floatary, 3.2f) << endl;
cout<<endl;
cout<<endl;
Apply2 ai2; //采用萃取
Apply2 af2; //采用萃取
cout << “2整型数组的和3倍:” <<ai2.GetSum(intary,3) << endl;
cout << “2浮点数组的和3.2倍:” << af2.GetSum(floatary,3.2f) << endl;
return 0;
}
复制代码
4.实例总结:

第①步:我们会发现代码冗余度很高,所以采用了第二种;

第②步:我们会发现在运用模板后,代码量是减少了,但是其类内部函数定义出现了固定形式的类型。若遇到复杂的问题,会导致数据的错误。

第③步:我们运用了traits机制,将根据不同类类型特化出相应的函数参数类型和返回值类型,这样就可以通过统一的接口,来实现不同的实例。

由此,萃取机制对我们编码的复用性,帮助还是很大的!!!!!!!

参考 https://www.cnblogs.com/single-dont/p/11403807.html

这篇关于STL traits的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/735391

相关文章

STL经典案例(四)——实验室预约综合管理系统(项目涉及知识点很全面,内容有点多,耐心看完会有收获的!)

项目干货满满,内容有点过多,看起来可能会有点卡。系统提示读完超过俩小时,建议分多篇发布,我觉得分篇就不完整了,失去了这个项目的灵魂 一、需求分析 高校实验室预约管理系统包括三种不同身份:管理员、实验室教师、学生 管理员:给学生和实验室教师创建账号并分发 实验室教师:审核学生的预约申请 学生:申请使用实验室 高校实验室包括:超景深实验室(可容纳10人)、大数据实验室(可容纳20人)、物联网实验

C++ STL 适配器

系列文章目录 模板特例化,偏特化,左右值引用 https://blog.csdn.net/surfaceyan/article/details/126794013 C++ STL 关联容器 https://blog.csdn.net/surfaceyan/article/details/127414434 C++ STL 序列式容器(二) https://blog.csdn.net/surfac

C++ STL关联容器Set与集合论入门

1. 简介 Set(集合)属于关联式容器,也是STL中最实用的容器,关联式容器依据特定的排序准则,自动为其元素排序。Set集合的底层使用一颗红黑树,其属于一种非线性的数据结构,每一次插入数据都会自动进行排序,注意,不是需要排序时再排序,而是每一次插入数据的时候其都会自动进行排序。因此,Set中的元素总是顺序的。 Set的性质有:数据自动进行排序且数据唯一,是一种集合元素,允许进行数学上的集合相

stl的sort和手写快排的运行效率哪个比较高?

STL的sort必然要比你自己写的快排要快,因为你自己手写一个这么复杂的sort,那就太闲了。STL的sort是尽量让复杂度维持在O(N log N)的,因此就有了各种的Hybrid sort algorithm。 题主你提到的先quicksort到一定深度之后就转为heapsort,这种是introsort。 每种STL实现使用的算法各有不同,GNU Standard C++ Lib

STL set整理

#include<set>#include<cstdio>#include<iterator>#include<iostream>#include<algorithm>using namespace std;//set 集合的操作//multisetset<int>Set1;set<int>Set2;set<int>Set3;/*begin() 返回指向第一个元素的迭代器

【C++STL(十四)】一个哈希桶简单模拟实现unordered_map/set

目录 前言 一、改造哈希桶 改造结点类 改造主体  模板参数改造  迭代器(重点) 改造完整哈希桶 unordered_map模拟实现 unordered_set模拟实现 前言 前面的文章都有说unordered_map/set的底层结构就是哈希表,严格来说是哈希桶,那么接下来我们就尝试使用同一个哈希桶来模拟实现一下。整体的逻辑和一棵红黑树封装map/set类似,所以

STL学习之零散记录(不断更新中)

我用到什么就写什么,所以不是太注重排版,等写多了以后再整理: 1:vector<int> V,V.pop_back()弹出最后一个元素 2:优先级队列不能设置迭代器,因为没有 3:   #include <bitset> //位运算 string str2(str,0,8);//将str字符串数组截取0~7号元素,string自带的功能bitset<8>

STL源码剖析之【二分查找】

ForwardIter lower_bound(ForwardIter first, ForwardIter last,const _Tp& val)算法返回一个非递减序列[first, last)中的第一个大于等于值val的位置。      ForwardIter upper_bound(ForwardIter first, ForwardIter last, const _Tp& val

Linux下新手如何将VIM配置成C++编程环境(可以STL自动补全)

~ 弄拉老半天,终于弄的差不多啦,果然程序员还是需要有点折腾精神啊。 首先你要安装vim,命令:sudo apt-get install vim vim它只是一个编辑器,它不是IDE(比如codeblocks),IDE相当于已经给一个房子装好啦各种东西,你只要使用就行,vim却要自己装各种东西,相当于买了一个毛坯房,自己要给房子装潢。 如何安装g++编译器可以参考我上一篇博文. 1:vi

STL栈与队列的基础用法

纯抄书,备忘。 栈: #include<stack>#include<cstdio>using namespace std;int main(){stack<int> s;//声明存储int类型数据的栈s.push(1);//{}->{1}s.push(2);//{1}->{1,2}s.push(3);//{1,2}->{1,2,3}printf("%d\n",s.top());/