二.traits(萃取机)

简介: 一.traits(萃取机)==traits分为俩种:==#### 1.iterator_traits负责萃取迭代器的性质(迭代器的特性->相应性别)。* 迭代器相应的型别分为五种:value type,difference type,pointer,reference,iterator_catagaly。1. ==value type==--------------迭代器所指对象的型别。2. ==difference type==-------表示俩个迭代器之间的距离,因此可以表示容器的最大容量。对于连续的空间来说,头尾之间的距离就是其中的 最大容量,例如STL

一.traits(萃取机)

==traits分为俩种:==

1.iterator_traits负责萃取迭代器的性质(迭代器的特性->相应性别)。

  • 迭代器相应的型别分为五种:value type,difference type,pointer,reference,iterator_catagaly。

1.value type--------------迭代器所指对象的型别。

2.difference type-------表示俩个迭代器之间的距离,因此可以表示容器的最大容量。对于连续的空间来说,头尾之间的距离就是其中的 最大容量,例如STL当中的count(),其传回值就必须使用这种迭代器。

3.reference type-------从迭代器所指之物的内容是否允许改变,所指对象内容不允许改变为 constant iterator. 例如const int p(常量指针),允许所指对象内容改变的为mutable iterator.例如 int p(普通指针)。

4.pointer type------------迭代器所指内容或者地址都可以。

5.iterator_catagaly-----根据移动特性将迭代器分为五种。

 * Input Iterator-------------只读,不能改变 (operator++)

* Output Iterator-----------只写 (operator++)

*  Forward Iterator---------读写 (operator++)

*  Bidirectional Iterator----双向移动 (operator++,operator–)

* Random Access Iterator-随机 (operator++,–,+n,-n,p1-p2,p1<p2 )

​ 继承关系

1661148661847.png

  • std::iterator的保证。为了符合规范,任何迭代器都应该提供五个内嵌相应型别,否则无法与其他STL组件顺利搭配。因此STL提供了一个iterator class如下,如果每个新设计 的迭代器都继承它,那么就可以保证符合STL所需规范:
template<class Category,class T,class Distance = ptrdifff_t,class Pointer = *T,class Reference = T&>
struct iterator{
     typedef Category     iterator_category;
     typedef T            value type;
     typedef Distance     difference_type;
     typedef Pointer      pointer;
     typedef Reference    referencec;
}
  • iterator_traits总结: 它的作用就是在无法确定类型性别的时候,通过它可以来获得参数的类型型别,例如:在函数重载过程中,为了更加高效快速的确定使用哪个版本的重载,这时可以用traits来萃取出它的类型型别,来确定使用哪一个重载函数。

2.__type_traits负责萃取型别的特性。

  • 型别的特性有:trivial ctor, copy ctor,assignment,dtor以及non-trivial ctor, copy ctor,assignment,dtor,如果答案是不重要的,那我们在对型别进行构造,析构,拷贝,赋值等操作时就可以采用最有效的措施(例如不需要调用constructor,destructor),而是采用内存直接处理操作如 malloc(),nencpy()等。

    举个例子:uninitalized_fill_n
template <class ForwardIterator, class Size, class T>
inline ForwardIterator uninitialized_ fill_ n (ForwardIterator first,Size n, const T& х) {
   
    return uninitialized_ fill_ n(first,n, x, value_ type(first)) ;
}
  • 该函数以x为蓝本,自迭代器first 开始构造n个元素。为求取最大效率, 首先以value_ type() (3.6 节)萃取出迭代器first 的value type,再利用 type traits 判断该型别是否为POD型别:
template <class ForwardIterator, class Size, class T, class T1> 
inline ForwardIterator uninitializeđ fill n (ForwardIterator first,Size n, const T&x, T1*)
{
    typedef typename _ type_ traits<Tl>::is_ POD_ _type is_ POD;
    return _uninitialized_ fill_ n_ aux(first, n, x, is_ _POD()) ;
}
  • 如果不是POD型别,就会执行下面措施
template <class ForwardIterator, class Size, class T>
ForwardIterator
__uninitialized_ fill_ n (ForwardIterator first,Size n, const T& х,__false_type){
    
ForwardIterator  cur = first;
    for (; n> 0;--n, ++cur)
           construct(&*cur, x);
    return cur;
}
  • 如果是POD型别,就会执行下面措施
template<class ForwardIterator, class Size, class T>
inline ForwardIterator
__uninitialized_fi11 n_ aux (ForwardIterator first, Size n,const T& X,一true_ type) 
{
    return fill_ n(first, n, x); //交由高阶函数执行, 如下所示
}
  • 以下是定义fill_n()
OutputIterator £111 n(OutputIterator first, Size n, const T& value) { 
    for( ; n> 0; --n, ++first)
         *first = value; 
    return first;
}
目录
相关文章
|
5月前
|
编解码 开发工具 vr&ar
DP活动:以太网HMI线下培训RA6M3 HMI Board[MQTT Squareline LVGL]
DP活动:以太网HMI线下培训RA6M3 HMI Board[MQTT Squareline LVGL]
108 1
|
存储 网络协议
小工具分享,电脑模拟pos机工具
小工具分享,电脑模拟pos机工具
|
网络协议 Linux 网络虚拟化
Linux 虚拟网络设备 veth-pair 详解,看这一篇就够了
Linux 虚拟网络设备 veth-pair 详解,看这一篇就够了 前面这篇文章介绍了 tap/tun 设备之后,大家应该对虚拟网络设备有了一定的了解,本文来看另外一种虚拟网络设备 veth-pair。
2829 0
|
Web App开发 网络协议 网络安全