博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C++标准库分析总结(三)——<迭代器设计原则>
阅读量:4330 次
发布时间:2019-06-06

本文共 802 字,大约阅读时间需要 2 分钟。

本节主要总结迭代器的设计原则,以及iterstor traits的设计作用

1、迭代器遵循的原则

迭代器是算法和容器的桥梁,它是类模板的设计,迭代器必须有能力回答算法提出的问题才能去搭配该算法的使用

1.1 算法使用迭代器示例

示例展示了rotate算法的,rotate(begin,middle,end),将区间[beg,end)内的元素进行旋转,执行后middle成为新的第一元素;

1.2 深刻分析迭代器的associated types

C++标准规定,所有的迭代器必须提供5种相关类型(associated types):

  • iterator-category:迭代器的类型,标准库提到了5中迭代器类型

    

 

  • value_type:迭代器的数据类型,放入的是哪种迭代器;
  • difference_type:两个迭代器间的距离;
  • pointer:迭代器的指针(算法目前没有使用);
  • reference:迭代器的引用(算法目前没有使用);

1.3 迭代器对于class和自然指针的处理

  在前面例子中,我们以list为例展示了迭代器的5种关联类型用于回答算法的提问,比如说value_type,它回答的是迭代器中放入元素的类型,但是对于放入的是C中的自然指针或者是class,迭代器又是怎么区分的呢?

  对于放入的class,迭代器可以直接回答,但是如果放入的是指针,指针是无法回答迭代器的5个提问的,这个时候就需要一种中间层来统一处理并作出回答,就有个traits的实现,对class和指针进行不同的处理。

1.4 迭代器的traits(萃取机)是如何工作的

  萃取机是为了回答迭代器中的5中相关类型而设计的,其中区分指针和class是通过偏特化实现的

  萃取机实现源码如下:

 

转载于:https://www.cnblogs.com/laiyingpeng/p/11185763.html

你可能感兴趣的文章
水平权限漏洞的修复方案
查看>>
静态链接与动态链接的区别
查看>>
Android 关于悬浮窗权限的问题
查看>>
如何使用mysql
查看>>
linux下wc命令详解
查看>>
敏捷开发中软件测试团队的职责和产出是什么?
查看>>
在mvc3中使用ffmpeg对上传视频进行截图和转换格式
查看>>
python的字符串内建函数
查看>>
Spring - DI
查看>>
微软自己的官网介绍 SSL 参数相关
查看>>
Composite UI Application Block (CAB) 概念和术语
查看>>
ajax跨域,携带cookie
查看>>
阶段3 2.Spring_01.Spring框架简介_03.spring概述
查看>>
阶段3 2.Spring_02.程序间耦合_1 编写jdbc的工程代码用于分析程序的耦合
查看>>
阶段3 2.Spring_01.Spring框架简介_04.spring发展历程
查看>>
阶段3 2.Spring_02.程序间耦合_3 程序的耦合和解耦的思路分析1
查看>>
阶段3 2.Spring_02.程序间耦合_5 编写工厂类和配置文件
查看>>
阶段3 2.Spring_01.Spring框架简介_05.spring的优势
查看>>
阶段3 2.Spring_02.程序间耦合_7 分析工厂模式中的问题并改造
查看>>
阶段3 2.Spring_02.程序间耦合_4 曾经代码中的问题分析
查看>>