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
    评论
STL实现迭代器萃取的方式是通过对iterator_traits进行偏特化。为了使迭代器萃取有效运行,每个迭代器都要自行以内嵌性别定义的方式定义出相应的型别。迭代器的类型萃取机制被定义为iterator_traits模板类,它接受一个迭代器类型作为模板参数,并通过特化来提取迭代器的相关信息。 在STL中,对于一般的迭代器类型,使用iterator_traits模板类进行萃取,通过迭代器的内嵌typedef来获取iterator_category、value_type、difference_type、pointer和reference等相应的型别。而针对原生指针类型的迭代器,STL会针对指针类型进行偏特化,直接定义出相应的型别,如random_access_iterator_tag、_Tp、ptrdiff_t、_Tp*和_Tp&等。这样就可以实现对迭代器的属性萃取。 通过对iterator_traits进行偏特化,STL能够根据不同的迭代器类型提取出相应的属性,从而能够在算法中正确地使用不同类型的迭代器,并根据迭代器的属性进行相应的操作。这样实现了迭代器的通用性和灵活性,使得STL算法可以适用于不同类型的迭代器。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [STL迭代器---萃取](https://blog.csdn.net/jiewaikexue/article/details/111372288)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [STL 迭代器萃取](https://blog.csdn.net/qq_40080842/article/details/128112675)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值