反向迭代器

反向迭代器

以list为例,我们完全可以再添加一个__list_reverse_iterator结构体,只需要修改++和–的逻辑

template <class T, class Ref, class Ptr>
struct __list_reverse_iterator
{
	...
	self& operator++()
	{
		_node = _node->_prev;
		return *this;
	}
	self operator++(int)
	{
		self tmp(*this);
		_node = _node->_prev;
		return tmp;
	}
	self& operator--()
	{
		_node = _node->_next;
		return *this;
	}
	self operator--(int)
	{
		self tmp(*this);
		_node = _node->_next;
		return tmp;
	}
	...
};
// 链表
template<class T>
class list
{
public:
	...
	typedef __list_reverse_iterator<T, T&, T*> reverse_iterator;
    reverse_iterator rbegin() { return _head->_prev; }
	reverse_iterator rend() { return _head; }
    ...
}

但是这样代码重复度太高了!而且自定义类型的迭代器才可以这样用,所以SGI版本的STL使用了迭代器适配模式
创立一个reverse_iterator.h,弱化了源码的萃取版本

template<class Iterator, class Ref, class Ptr>
class reverse_iterator
{
	Iterator current;
public:
	typedef reverse_iterator<Iterator, Ref, Ptr> self;
	reverse_iterator(Iterator it) 
		: current(it) {}

	Ref operator*()
	{
		// 这样做的原因是因为rbegin()最开始在越位位置
		Iterator tmp = current;
		--tmp;
		return *tmp;
	}

	self& operator++()
	{
		--current;
		return *this;
	}
	self operator++(int)
	{
		self tmp(*this);
		--current;
		return tmp;
	}

	self& operator--()
	{
		++current;
		return *this;
	}
	self operator--(int)
	{
		self tmp(*this);
		++current;
		return tmp;
	}
	bool operator!=(const self& x)
	{
		return current != x.current;
	}
};

// 链表
template<class T>
class list
{
public:
	...
    typedef reverse_iterator<iterator, T&, T*> reverse_iterator;
    typedef reverse_iterator<iterator, const T&, const T*> const_reverse_iterator;
    reverse_iterator rbegin() { return reverse_iterator(end()); }
    reverse_iterator rend() { return reverse_iterator(begin()); }
    const_reverse_iterator rbegin() const { return const_reverse_iterator(end()); }
    const_reverse_iterator rend() const { return const_reverse_iterator(begin()); }
    ...
}

单独写一个迭代器的类不仅减少了代码的冗余,其他容器也可以很好的适用

  • 9
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值