迭代器是什么

    在学习c++ STL的时候,整天碰到迭代器,也整天用,但是,到底它是个什么东西,很多人没有一个认识。这里我通过几个小的DEMO,来看看迭代器。首先我实现了一个十分简陋的vector类:

template <class T>  
  1. class vector {  
  2. private:  
  3.     T* pbegin;  
  4.     int n; //当前大小  
  5. public:  
  6.     vector() {  
  7.         pbegin = new T[100]; //暂时先固定大小  
  8.         n = 0;  
  9.     }  
  10.       
  11.     T* begin() {  
  12.         return pbegin;  
  13.     }  
  14.     void insert(T d){  
  15.         pbegin[n++] = d;  
  16.     }  
  17.     typedef T* iterator; //vector的迭代器就是基础指针类型  
  18. };  

我们知道,vector是数组实现的,也就是说,只要知道数组的首地址,就能知道后面每个元素的位置,所以,访问vector的迭代器,其实就是一个基础的指针类型,我们可以通过++,--等操作,来遍历访问该vector。

//测试vector   
  1.     vector<int> a;  
  2.     a.insert(1);  
  3.     a.insert(2);  
  4.     vector<int>::iterator itra;  
  5.     itra = a.begin();  
  6.     printf("%d/n", *itra);   
  7.     itra++;  
  8.     printf("%d/n", *itra);  
  9.     itra--; //基础指针类型都支持++,--,+,-等操作符   
  10.     printf("%d/n", *itra);  

哇~~,原来vector的迭代器那么简单,那么,我们来考虑一下List,这是链表,我们知道,链表每个元素都存储在不同的位置,我们一般通过指向下一个元素的next指针来找到下一个元素。那么,我们怎么样来设计一个迭代器,然后可以直接对这个迭代器进行++,--等操作二遍历访问整个链表呢:

template <class T>  
  1. class List{  
  2. private:  
  3.     struct Node{ //链表的节点  
  4.         T data;  
  5.         Node* next;  
  6.     };  
  7.     Node* pbegin; //表头   
  8.     class List_iterator{ //链表的迭代器  
  9.         Node* cur; //当前指向   
  10.     public:  
  11.         void operator = (Node* ptr) {  
  12.             cur = ptr;  
  13.         }  
  14.         void operator ++ () {  
  15.             cur = cur->next;  
  16.         }  
  17.         // ...还可以重载-- + -等操作符   
  18.         T operator * (){  
  19.             return cur->data;  
  20.         }  
  21.     };  
  22. public :  
  23.     List() {  
  24.         pbegin=NULL;  
  25.     }  
  26.     Node* begin() {  
  27.         return pbegin;  
  28.     }  
  29.     void insert(T d) {  
  30.         Node* p=pbegin;  
  31.         while(p && p->next) p=p->next;  
  32.         Node* t = new Node;  
  33.         t->data = d;  
  34.         t->next = NULL;  
  35.         if(pbegin==NULL)  
  36.             pbegin = t;  
  37.         else  
  38.             p->next = t;  
  39.     }  
  40.     typedef List_iterator iterator; //List的迭代器是一个类  
  41. };  

为List设计的迭代器是一个类,这个类支持++操作来向后移动遍历链表:

/测试List  
  1.     List<int> b;  
  2.     b.insert(1);  
  3.     b.insert(2);  
  4.     List<int>::iterator itrb;  
  5.     itrb = b.begin();  
  6.     printf("%d/n", *itrb);  
  7.     itrb++; // 该迭代器只支持++   
  8.     printf("%d/n", *itrb);   

通过这两个例子,可以看出,迭代器是跟容器紧密结合的,不同的容器,它的迭代器不同,但是,他们有共同的目标,就是可以通过该迭代器,来遍历访问这个容器里面的元素。这样带来的好处是在STL设计算法时,可以脱离容器而设计更加通用的算法。比如,在容器中查找一个元素。查找,这个操作一般来说就是遍历整个集合,然后找到那个要找的元素,但是,如果没有迭代器,我们需要为vector和List设计两个查找算法,因为找下一个元素在vector和List中的操作不同。同样的思想却要两套代码,显然这是不优秀的。

      有了模板,我们可以将算法和特定的数据分离开来,而有了迭代器,我们可以将算法和特定的容器分离开来。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值