C++_泛型编程与标准库(六)
1、iterator几个特定属性
vc2019的链表list迭代器部分代码
template <class _Mylist>
class _List_iterator : public _List_const_iterator<_Mylist> {
public:
using _Mybase = _List_const_iterator<_Mylist>;
using iterator_category = bidirectional_iterator_tag;
using _Nodeptr = typename _Mylist::_Nodeptr;
using value_type = typename _Mylist::value_type;
using difference_type = typename _Mylist::difference_type;
using pointer = typename _Mylist::pointer;
using reference = value_type&;
using _Mybase::_Mybase;
......
}
我的理解是list中迭代器iterator是类型重定义,即别名,具体代码如下:
using iterator = _List_iterator<_Scary_val>;
其中迭代器_Scary_val是类型重定义,即别名,具体代码如下:
using _Val_types = conditional_t<_Is_simple_alloc_v<_Alnode>, _List_simple_types<_Ty>,
_List_iter_types<_Ty, typename _Alty_traits::size_type, typename _Alty_traits::difference_type,
typename _Alty_traits::pointer, typename _Alty_traits::const_pointer, _Ty&, const _Ty&, _Nodeptr>>;
using _Scary_val = _List_val<_Val_types>;
然后传递给_List_iterator,在_List_iterator里重定义,和GNU2.9的类似
下图是GNU2.9与4.9的_list_iterator
2、指针也属于迭代器的一种,迭代器可以说是泛化指针———Iterator Traits
traits具体运作如下
参考:侯捷泛化编程与标准库、VC2019、《C++Primer》
|