type traits小总结

4 篇文章 0 订阅

主要是阅读了侯捷老师的《stl源码剖析》的迭代器部分的内容,进行的一点总结:

  1. type traits是什么?
    字面翻译,就是类型特点,顾名思义,就是某个类本身的特质。在下图中,迭代器是容器和算法之间的桥梁,而算法在调用使用数据的过程中,也需要知道这个数据或者说容器本身的性质。
    迭代器在容器和算法中的作用
  2. 迭代器中的type traits有哪些?
template <class I>
struct iterator_traits {
 	typedef typename I::iterator_category iterator_category; //迭代器类别(按照移动特性划分)
 	typedef typename I::value_type value_type;
 	typedef typename I::difference_type difference_type;
 	typedef typename I::pointer pointer;
 	typedef typename I::reference reference;
 	//关于迭代器类别,一共有五种:InputIterator, OutputIterator, ForwardIterator, 
 	BidirectionalIterator, RandomAccessIterator
 	//关于value_type,就是迭代器中元素的类别,如vector<int>,那么value_type就是int
 	//关于difference_type,是迭代器中两个迭代器之间的距离,
 	//关于pointer和reference,就分别是指针和引用
}

以上只是支持了迭代器,而实际上考虑具体应用,还应该满足指针和指向常量对象的指针,即需要偏特化

//迭代器版本
template<class T>
struct iterator_traits {
	typedef typename T::value_type value_type;
}
//支持指针
template <class T>
struct iterator_traits<T*> {
	typedef T value_type;
}
//支持指向常量的指针
template <class T>
struct iterator_traits<const T*> {
	typedef T value_type; //这里去掉const,因为实际意义不大
}
  1. 设计type traits
    有一个技巧:就是这里需要首先去除const和volatile关键字
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值