STL学习 记录

来源:互联网 发布:网络剧上瘾 台湾版 mp4 编辑:程序博客网 时间:2024/06/05 20:17
STL组件中另一个别具特色的组件:迭代器。每个标准迭代器都至少包含五中内嵌型别: value_type 所指物的类型 difference_type 元素距离 reference_type 所指物的引用 pointer_type 所指物的指针 iterator_category 迭代器的种类其中需要重点关注的是iterator_category,迭代器的种类又包括: input iterator output iterator forward iterator bidirectional iterator random access iterator 《STL源码剖析》中示例: //移动单向只读迭代器template < class InputIterator, class Distance >void advance_II(InputIterator& i, Distance n){ while (n--) ++i;}//移动双向迭代器template < class BidirectionalIterator, class Distance >void advance_BI(BidirectionalIterator& i, Distance n){ if (n >= 0) while (n--) ++i; else while (n++) --i;}//移动随机迭代器template < class RandomAccessIterator, class Distance >void advance_BAI(RandomAccessIterator& i, Distance n){ i += n;} //注意:对外我们只提供一个advace接口,可能我们类似如下做法:template < calss InputIterator, class Distance >void advance(InputIterator& i, Distance n){ if (is_random_access_iterator(i)) //假设可以通过这个函数来判断是否是随机迭代器 advance_BAI(i, n); else if (is_bidirectional_iterator(i)) //同上 advance_BI(i, n); else advance_II(i, n); //同上}这里存在的问题是对i类型的判断是在程序运行时,影响程序效率。STL使用重载技术解决这个问题:为了令其同名,形成重载我们必须加上一个型别已经确定的参数,使函数重载机制得以有效的运作起来。如果traits有能力萃取出迭代器的种类,我们便可以利用这个迭代器类型作为advance函数的第三个参数。这个相应的型别一定是一个class,不能只是类似枚举的数值,因为编译器需要依赖它(一个类型)来进行重载。下面定义5个class代表五中迭代器类型: struct input_iterator_tag{};struct output_iterator_tag{};struct forward_iterator_tag:public input_iterator_tag {};struct bidirectional_iterator_tag:public forward_iterator_tag {};struct random_access_iterator_tag:public bidirectional_iterator_tag {}; 各种迭代器的advance重载实现如下://只读迭代器移动 template< class InputIterator, class Distance> inline void __advance(InputIterator& i, Distance n, input_iterator_tag) { while (n--) ++i; } //读写迭代器移动 template< class ForwardIterator, class Distance> inline void __advance(ForwardIterator& i, Distance n, forward_iterator_tag) { __advance(i, n, input_iterator_tag()) } //双向读写迭代器移动 template< class BidiectionalIterator, class Distance> inline void __advance(BidiectionalIterator& i, Distance n, bidirectional_iterator_tag) { if (n > 0) { while (n--)++i; } else { while (n++)--i; } } //随机读写迭代器移动 template< class RandomAccessIterator, class Distance> inline void __advance(RandomAccessIterator& i, Distance n, random_access_iterator_tag) { i += n; } //========================== //对外开放的接口: //========================== template< class InputIterator, class Distance> inline void advance(InputIterator& i, Distance n) { //这里再次通过traits机制调用具体的__advance函数: __advance(i, n, iterator_traits::interator_category());//通过萃取获取第三个参数 }而红色部分需要定义迭代器萃取结构并且偏特化:template < class I> //这个I就是我们自定义的迭代器类型,内部需要有以下5种内嵌型别 struct iterator_traits { typedef typename I::value_type value_type; typedef typename I::iterator_category interator_category; typedef typename I::difference_type differrnce_type; typedef typename I::pointer pointer; typedef typename I::reference reference; }; template < class I> struct iterator_traits { typedef I value_type; typedef random_access_iterator_tag interator_category; typedef ptrdiff_t differrnce_type; typedef I* pointer; typedef I& reference; };//如果我们要自己写一个迭代器类,结构大致如下(假设迭代器所指之物为int):class MyIterator{ typedef int value_type; typedef random_access_iterator_tag interator_category; typedef ptrdiff_t differrnce_type; typedef int* pointer; typedef int& reference;}
0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 德国领事馆没有收到预约邮件怎么办 父母一方带孩子英国签证怎么办 去韩国自由行签证怎么办 韩国自由行签证的该怎么办 法院离婚判决书没了怎么办 离婚判决书对方没收到怎么办 法院判离怎么办离婚证 判决书下来后没钱还怎么办 拿调解书怎么办离婚证 判决书生效后对方拒不履行怎么办 收到民事判决公告该怎么办 苹果手机gps信号弱怎么办 二审败诉后拿到判决书怎么办 农商行房贷逾期一天怎么办 农商行房贷逾期怎么办 农发行车改司机怎么办 混泥土地泵排量不稳怎么办 改嫁上海老公孩子的户口怎么办 给小孩办社保卡怎么办 有上海居住证积分怎么办医保 未办理居住证积分新生儿医保怎么办 厦门中考居住证没满三年怎么办 海归落户过了两年期怎么办 借呗学历填错了怎么办 上海落户应届生分不够怎么办 应届生落户分数不够72分怎么办? 上海应届生落户时间延误怎么办 南京市区户口签江宁怎么办 深圳公司集体户口离职后怎么办 济南本地户口不符合入学条件怎么办 上海住亲戚家怎么办居住证 政府卖非农户口怎么办 90年代买了户口怎么办 上海应届大学生积分不够怎么办 广州居住证回执单丢了怎么办 惠阳居住证回执单丢了怎么办 南京居住证换地方了怎么办 买家退回的商品有问题怎么办 农转农户口手续怎么办 原房东不迁户口我怎么办 户主信息页掉了怎么办