一、迭代器设计原则
迭代器是容器与算法处理的桥梁
category分类,类别
difference_type两个迭代器之间的距离的类型,容器最大能放多少元素,超过differene_type会有问题。
迭代器的设计原则需要5中type,5种type叫做迭代器iterator associated types关联
2.为什么设计iterator_traits
算法向迭代器提问,迭代器回答
为什么需要iterator_traits?算法要问一些问题,指针不能回答出来。iterator_traits区分class的iterator还是native pointer
具体做法:
(1)为了应付指针的形式,加一个中间层iterator_traits
(2)利用偏特化的语法分离出指针T*,或者const T*
三、设计iterator_traits
为什么cont T*类型traits的类型是T?萃取出的value_type目的是用来声明变量,而声明一个无法被赋值的变量没什么应用,所以iterator(即便是constant iterator)的value type不应加上const