【C++/STL】list(常见接口、模拟实现、反向迭代器)

2024-06-08 1142阅读

 🌈个人主页:秦jh_-CSDN博客
🔥 系列专栏:https://blog.csdn.net/qinjh_/category_12575764.html?spm=1001.2014.3001.5482

【C++/STL】list(常见接口、模拟实现、反向迭代器)

目录

前言

 list的常见接口

对迭代器的封装

 节点

重载->

const迭代器

list与vector的对比

反向迭代器

 反向迭代器完整代码

list完整代码


前言

    💬 hello! 各位铁子们大家好哇。

             今日更新了list的相关内容

    🎉 欢迎大家关注🔍点赞👍收藏⭐️留言📝

 list的底层是双向链表结构,双向链表中每个元素存储在互不相关的独立节点中,在节点中通过指针指向其前一个元素和后一个元素。

 list的常见接口

【C++/STL】list(常见接口、模拟实现、反向迭代器)【C++/STL】list(常见接口、模拟实现、反向迭代器)【C++/STL】list(常见接口、模拟实现、反向迭代器)【C++/STL】list(常见接口、模拟实现、反向迭代器)【C++/STL】list(常见接口、模拟实现、反向迭代器)

对迭代器的封装

【C++/STL】list(常见接口、模拟实现、反向迭代器)

因为list的空间不是连续的,不能用原生指针,必须对其进行封装。 

 节点

【C++/STL】list(常见接口、模拟实现、反向迭代器)

重载->

【C++/STL】list(常见接口、模拟实现、反向迭代器)

【C++/STL】list(常见接口、模拟实现、反向迭代器)

当数据是自定义类型时,想通过->访问,就必须重载。 

const迭代器

【C++/STL】list(常见接口、模拟实现、反向迭代器)【C++/STL】list(常见接口、模拟实现、反向迭代器)【C++/STL】list(常见接口、模拟实现、反向迭代器)

用const迭代器,需要重新弄一个类,而const迭代器跟普通迭代器基本一样,只修改了部分,如果为此就重新弄一个类,代码就太冗余了。

  下面是进行的优化:

【C++/STL】list(常见接口、模拟实现、反向迭代器)【C++/STL】list(常见接口、模拟实现、反向迭代器)

本质相当于写了一个类模板,编译器实例化生成了两个类。

list与vector的对比

【C++/STL】list(常见接口、模拟实现、反向迭代器)

反向迭代器

反向迭代器的++就是正向迭代器的--,反向迭代器的--就是正向迭代器的++,因此反向迭代器的实现可以借助正向迭代器,即:反向迭代器内部可以包含一个正向迭代器,对正向迭代器的接口进行 包装即可。

【C++/STL】list(常见接口、模拟实现、反向迭代器)【C++/STL】list(常见接口、模拟实现、反向迭代器)

 反向迭代器完整代码

#pragma once 
//所以容器的反向迭代器
//迭代器适配器
namespace qjh
{
	//vector::iterator
	template  //给谁的正向迭代器,就适配出对应的反向迭代器
	struct ReverseIterator   
	{
		typedef ReverseIterator Self;
		Iterator _it;
		
		ReverseIterator(Iterator it)
			:_it(it)
		{}
		Ref operator*()
		{
			Iterator tmp = _it;  //不能修改_it,得用临时变量放回
			return *(--tmp);
		}
		Ptr operator->()
		{
			//return _it->;
			//return _it.operator->();
			return &(operator*());
		}
		Self& operator++()
		{
			--_it;
			return *this;
		}
		Self& operator--()
		{
			++_it;
			return *this;
		}
		bool operator!=(const Self& s)
		{
			return _it != s._it;
		}
	};
}

list完整代码

#pragma once
#include
#include"ReverseIterator.h"	
namespace qjh
{
	template
	struct ListNode   //需要全部被公开,用struct
	{
		ListNode* _next;
		ListNode* _prev;
		T _data;
		ListNode(const T& x=T())
			:_next(nullptr)
			,_prev(nullptr)
			,_data(x)
		{}
	};
	template
	struct ListIterator    //对指针进行封装,因为结点的空间不是连续的
	{
		typedef ListNode Node;
		typedef ListIterator Self;
		 
		Node* _node;
		ListIterator(Node* node)
			:_node(node)
		{}
		//*it
		//T& operator*()
		Ref operator*()
		{ 
			return _node->_data;
		}
		//T* operator->()
		Ptr operator->()
		{
			return	&_node->_data;
		}
		//++it
		Self& operator++()
		{
			_node = _node->_next;
			return *this;
		}
		//it++
		Self& operator++(int)
		{
			Self tmp(*this);
			_node = _node->_next;
			return tmp;
		}
		//--it
		Self& operator--()
		{
			_node = _node->_prev;
			return *this;
		}
		//it--
		Self& operator--(int)
		{
			Self tmp(*this);
			_node = _node->_prev;
			return tmp;
		}
		bool operator!=(const Self& it)
		{
			return _node != it._node;
		}
		bool operator==(const Self& it)
		{
			return _node == it._node;
		}
	};
	//template
	//struct ListConstIterator    //对指针进行封装,因为结点的空间不是连续的
	//{
	//	typedef ListNode Node;
	//	typedef ListConstIterator Self;
	//	Node* _node;
	//	ListConstIterator(Node* node)
	//		:_node(node)
	//	{}
	//	//*it
	//	const T& operator*()
	//	{
	//		return _node->_data;
	//	}
	//	const T* operator->()
	//	{
	//		return	&_node->_data;
	//	}
	//	//++it
	//	Self& operator++()
	//	{
	//		_node = _node->_next;
	//		return *this;
	//	}
	//	//it++
	//	Self& operator++(int)
	//	{
	//		Self tmp(*this);
	//		_node = _node->_next;
	//		return tmp;
	//	}
	//	//--it
	//	Self& operator--()
	//	{
	//		_node = _node->_prev;
	//		return *this;
	//	}
	//	//it--
	//	Self& operator--(int)
	//	{
	//		Self tmp(*this);
	//		_node = _node->_prev;
	//		return tmp;
	//	}
	//	bool operator!=(const Self& it)
	//	{
	//		return _node != it._node;
	//	}
	//	bool operator==(const Self& it)
	//	{
	//		return _node == it._node;
	//	}
	//};
	template
	class list
	{
		typedef ListNode Node;
	public:
		/*typedef ListIterator iterator;
		typedef ListConstIterator const_iterator;*/
		typedef ListIterator iterator;
		typedef ListIterator const_iterator;
		typedef ReverseIterator reverse_iterator;
		typedef ReverseIterator const_reverse_iterator;
		reverse_iterator rbegin()
		{
			return reverse_iterator(end());
		}
		reverse_iterator rend()
		{
			return reverse_iterator(begin());
		}
		iterator begin()
		{
			return iterator(_head->_next);
		}
		iterator end()
		{
			return iterator(_head);
		}
		//const迭代器需要迭代器指向的内容不能修改!const iterator不是我们需要的const迭代器
		//const 迭代器本身可以++等操作
		const_iterator begin() const
		{
			return const_iterator(_head->_next);
		}
		const_iterator end() const
		{
			return const_iterator(_head);
		}
		void empty_init()
		{
			_head = new Node;
			_head->_next = _head;
			_head->_prev = _head;
			_size = 0;
		}
		list()
		{
			empty_init();
		}
		list(initializer_list il)
		{
			empty_init();
			for (auto& e : il)
			{
				push_back(e);
			}
		}
		//lt2(lt1)
		list(const list& lt)
		{
			empty_init();
			for (auto& e : lt)
			{
				push_back(e);
			}
		}
		void swap(list& lt)
		{
			std::swap(_head, lt._head);
			std::swap(_size, lt._size);
		}
		//lt1=lt3
		list& operator=(list lt)
		{
			swap(lt);
			return *this;
		}
		void clear()
		{
			iterator it = begin();
			while (it != end())
			{
				it = erase(it);
			}
		}
		~list()
		{
			clear();
			delete _head;
			_head = nullptr;
		}
		//void push_back(const T& x)
		//{
		//	Node* newnode = new Node(x);
		//	Node* tail = _head->_prev;
		//	tail->_next = newnode;
		//	newnode->_prev = tail;
		//	newnode->_next = _head;
		//	_head->_prev = newnode;
		//}
		void push_back(const T& x)
		{
			insert(end(), x);
		}
		void push_front(const T& x)
		{
			insert(begin(), x);
		}
		void pop_back()
		{
			erase(--end());//迭代器不能-1,只能用-- 
		}
		void pop_front()
		{
			erase(begin());
		}
		void insert(iterator pos, const T& val)
		{
			Node* cur = pos._node;
			Node* newnode = new Node(val);
			Node* prev = cur->_prev;
			prev->_next = newnode;
			newnode->_prev = prev;
			newnode->_next = cur;
			cur->_prev = newnode;
			_size++;
		}
		iterator erase(iterator pos) //节点失效了,需要返回下一个节点
		{
			Node* cur = pos._node;
			Node* prev = cur->_prev;
			Node* next = cur->_next;
			prev->_next = next;
			next->_prev = prev;
			delete cur;
			_size--;
			return iterator(next); //匿名对象
		}
		size_t size() const
		{
			return _size;
		}
		bool empty()
		{
			return _size == 0;
		}
	private:
		Node* _head;
		size_t _size;
	};
	void test_list1()
	{
		list lt;
		lt.push_back(1);
		lt.push_back(2);
		lt.push_back(3);
		lt.push_back(4);
		lt.push_back(5);
		list::iterator it = lt.begin();
		while (it != lt.end())
		{
			cout 
VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]