当前位置: 首页 > news >正文

中国建设银行黄冈分行网站淘宝网站设计公司

中国建设银行黄冈分行网站,淘宝网站设计公司,做外贸需要关注的网站有什么好处,肇庆市企业网站建设品牌一、反向迭代器 在list模拟实现的过程中,第一次接触了迭代器的封装,将list的指针封装成了一个新的类型,并且以迭代器的基本功能对其进行了运算符重载 反向迭代器是对正向迭代器的封装,并且体现了泛型编程的思想,任意…

一、反向迭代器

在list模拟实现的过程中,第一次接触了迭代器的封装,将list的指针封装成了一个新的类型,并且以迭代器的基本功能对其进行了运算符重载

反向迭代器是对正向迭代器的封装,并且体现了泛型编程的思想,任意类型的双向迭代器都可以直接复用反向迭代器

本章将把两个迭代器的实现放在一起比对,更好的体会迭代器的封装

二、list正向迭代器的模拟实现

详解可以看list模拟实现那一章节,这里仅提供一份代码用于对照反向迭代器

	template<class T,class Ref,class Ptr>struct __list_iterator{typedef list_node<T> node;typedef __list_iterator<T, Ref, Ptr> self;node* _pnode;__list_iterator(node* p):_pnode(p){}self& operator++(){_pnode = _pnode->_next;return *this;}self& operator--(){_pnode = _pnode->_prev;return *this;}self operator++(int){self tmp(_pnode);_pnode = _pnode->_next;return tmp;}self operator--(int){self tmp(_pnode);_pnode = _pnode->_prev;return tmp;}Ref operator*(){return _pnode->_data;}Ptr operator->(){return &(_pnode->_data);}bool operator!=(const self& p){return _pnode != p._pnode;}bool operator==(const self& p){return _pnode == p._pnode;}};

三、反向迭代器的封装实现(双向迭代器)

反向迭代器的实现是对正向迭代器的封装

1.成员及其初始化

template<class Iterator,class Ref,class Ptr>
struct ReserveIterator
{typedef ReserveIterator self;//重命名方便使用Iterator _it;//成员变量ReserveIterator(Iterator it):_it(it){}
}

2.基本功能的重载

(1) ++ 和 --

在反向迭代器的概念中,反向迭代器++,就是正向迭代器--

self& operator++()
{_it--;return *this;
}
self& operator--()
{_it++;return *this;
}
//前置++和--
self operator++(int)
{self tmp(*this);_it--;return tmp;
}
self operator--(int)
{self tmp(*this);_it++;return tmp;
}

(2) != 和 ==

bool operator!=(const self& s)
{return _it != s._it;
}
bool operator==(const self& s)
{return _it == s._it;
}

(3) -> 和 *

在实现operator*()之前,要先理解底层,在stl库内的实现,为了让begin()和rend(),所在的物理空间上对称,但在使用的角度上来看,并不对称,为了使其对称,且不影响使用,对*和->的实现作出了调整,解引用返回的是其前一个的位置

Ref operator*()
{Iterator tmp(_it);_it--;return *tmp; 
}
Ptr operator->()
{Iterator tmp(_it);_it--;return &(*_it);
}

3.定义部分

		typedef __list_iterator<T, T&, T*> iterator;typedef __list_iterator<T, const T&, const T*> con_iterator;typedef ReverseIterator<iterator, T&, T*> reverse_iterator;typedef ReverseIterator<iterator,const T&,const T*> con_reverse_iterator;iterator begin(){return iterator(_head->_next);}iterator end(){return iterator(_head);}con_iterator begin()const{return con_iterator(_head->_next);}con_iterator end()const{return con_iterator(_head);}reverse_iterator rbegin(){return reverse_iterator(end());}reverse_iterator rend(){return reverse_iterator(begin());}

总结

本章整理了关于反向迭代器的相关内容,以及模拟实现

http://www.yayakq.cn/news/27037/

相关文章:

  • 义务 网站建设龙岗中心城网站建设
  • 做设计的素材网站如何分析网站
  • 做网站建设公司怎么样北京网站备案查询
  • 盛唐网站建设简单大气静态网页模板
  • 十堰网站建设多少钱苏州网站定制
  • 外国域名注册很多网站天津建设工程信息网的ca花钱吗
  • 模块网站建设企业管理
  • 个人网站模板 html5网络营销网站平台有哪些
  • 怎么做网站静态布局未成年怎么在网上卖东西
  • 网站开发涉及到哪些知识产权一般网站版式有哪几种
  • 生产企业做网站有用吗网站开发微信支付
  • 小学最好的网站建设网页升级中紧急自动转跳中
  • 广州 济南网站建设公司 网络服务上海网站定制设计
  • 阜新网站开发常州网站推广培训
  • fusion做电影网站卡死纪检部门网站举报建设
  • 宜宾市珙县住房城乡建设网站海南直聘网
  • 自己做网站排名好吗wordpress 梦月酱
  • 阜新门户网站建设腾讯云服务器
  • 个人网站 网站教程自学网站开发需要看什么书
  • 贵阳做网站的公司厦门建设网站公司
  • 能免费做封面的网站wordpress 移动端 主题
  • 百度站长平台网站验证已经有域名 怎么修改网站
  • 华为模板建站网络规划设计师月薪多少
  • 阿里云esc建设网站企业网站后台模板
  • 天峨县建设局网站网站怎么分工做
  • 做网站一定要用cms吗wordpress调用网站标题
  • 爬取数据做网站健身房网站建设
  • 自己怎么做视频网站泉州服装网站建设
  • 小说网站开发过程 实训报告沈阳seo搜索排名优化
  • 网站建设的销售术语微软手机做网站服务器