STL源码剖析—Iterator与Traits

Iterator行为类似指针,实现较为简单。这里主要介绍一下Traits。

为什么要用Traits?

使用Traits可以方便我们获取迭代器的相关信息。

获取迭代器的类型

如果函数中想要获取迭代器的类型该怎么做呢?下面提供一种方法:

template <class I, class T>
void func_impl(I iter, T t) {
    T tmp;
    // ...
}
template <class I>
void func(I iter) {
    func_impl(iter, *iter);
}
int main(){
    int i;
    func(&i);
}

通过模板的参数推导,我们得到了迭代器的类型。但是如果函数的返回值用到了该类型怎么办呢?模板是无法推导函数的返回值类型的。

template <class T>
class MyIter {
    typedef T value_type;
    T* ptr;
    MyIter(T* p) : ptr(p) {}
    T& operator*() const { return *ptr; }
};
template <class I>
typename I::value_type func(I ite) {
    return *ite;
}
MyIter<int> ite(new int(1));
cout << func(ite);

我们通过将推导出的类型T定义为value_type来实现。然而还有一个问题,如果迭代器就是一个指针,不是一个class,无法对其进行typedef,该怎么办呢?

我们设计一个类用来萃取迭代器的类型。

template <class T>
class iterator_traits {
    typedef typename I::value_type value_type;
};
template <class T>
class iterator_traits<T*> {
    typedef T value_type;
};
template <class I>
typename iterator_traits<I>::value_type func(I ite) {
    return *ite;
}

多了iterator_traits这一层,我们可以对其进行偏特化,实现对指针类型的萃取,这样就完美解决了问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值