C++ stl迭代器的理解

首先,stl采用了泛型编程,分成了容器和算法,容器和算法之间的桥梁是迭代器,迭代器的作用是可以让算法不区分容器来作用在数据上。

迭代器本质上是指针,原有类型(比如int,double等)的指针也可以是迭代器,那如何让代码区分开他们呢?

我们可以把自定义的迭代器包装成一个对象,原有类型的还是指针,使用偏特化就可以区分开自定义迭代器和原有类型指针。可以这么干

cpp 复制代码
template<typename T>
class myIterator{
public:
    using value_type = T;
    myIterator(T* iter) : ptr(iter){}
    T& operator*(){
        return *ptr;
    }
public:
    T* ptr;
};

template<typename Iterator>
struct myIterator_traits{
    using value_type = typename Iterator::value_type;
};

template<typename Iterator>
struct myIterator_traits<Iterator*>{
    using value_type = Iterator;
};

template<typename Iterator>
struct myIterator_traits<const Iterator*>{
    using value_type = Iterator;
};

template<typename T>
typename myIterator_traits<T>::value_type func(T begin){
    typedef typename myIterator_traits<T>::value_type return_type;
    return_type res=*begin;
    return res;
}

int main(){
    myIterator<int> a(new int(10));
    cout<<func(a)<<endl;
    int* b=new int(5);
    cout<<func(b)<<endl;
    const int* c=new int(1);
    cout<<func(c)<<endl;
    return 0;
}

这样借用偏特化使用内嵌类型就得到了传入的类型,也叫萃取。

如果不使用萃取,也就是myIterator_traits这个结构,是无法解决传入类型为int*这种的,因为int可没有value_type。

这是一篇小笔记,怕忘了,随手记录

相关推荐
A boy CDEF girl4 分钟前
【JavaEE】阻塞队列
java·开发语言·java-ee
Maple_land29 分钟前
C++入门——命名空间
c++
酷爱码31 分钟前
2025DNS二级域名分发PHP网站源码
开发语言·php
MSTcheng.34 分钟前
【C语言】动态内存管理
c语言·开发语言·算法
热心市民小汪35 分钟前
管理conda下python虚拟环境
开发语言·python·conda
小韩学长yyds42 分钟前
Java调用第三方HTTP接口:从入门到实战
java·开发语言·http
McQueen_LT44 分钟前
聊天室Python脚本——ChatGPT,好用
开发语言·python·chatgpt
如鱼得水不亦乐乎1 小时前
C Primer Plus 第十章练习
c语言·开发语言
桃酥4031 小时前
20、移动语义有什么作用,原理是什么【中高频】
c++
闻缺陷则喜何志丹1 小时前
【二分查找、滑动窗口】P10389 [蓝桥杯 2024 省 A] 成绩统计|普及+
c++·算法·蓝桥杯·二分查找·滑动窗口·洛谷·成绩