模拟C++中的vector容器

本文介绍了如何从头开始模拟C++标准库中的vector容器,包括基本操作如初始化、大小获取、元素访问、插入、删除以及内存管理。通过实例展示了vector的构造、析构、迭代器使用以及关键方法如reserve和resize的实现。
摘要由CSDN通过智能技术生成

模拟C++中的vector容器

代码实现

#define _CRT_SECURE_NO_WARNINGS 1
#include<iostream>
#include<vector>
#include<vld.h>
#include<assert.h>
using namespace std;

namespace bit
{
	template<class T>
	class vector
	{
	public:
		typedef T* iterator;
	public:
		vector() : _start(nullptr), _finish(nullptr), _end_of_storage(nullptr)
		{}
		vector(initializer_list<T> il) : _start(nullptr), _finish(nullptr), _end_of_storage(nullptr)
		{
			reserve(il.size());
			for (auto& e : il)
				push_back(e);
		}
		~vector()
		{
			if (_start)
				delete[]_start;
			_start = _finish = _end_of_storage = nullptr;
		}
	public:
		iterator begin()const
		{
			return _start;
		}
		iterator end()const
		{
			return _finish;
		}
	public:
		size_t size()const
		{
			return _finish - _start;
		}
		size_t capacity()const
		{
			return _end_of_storage - _start;
		}
		bool empty()const
		{
			return _start == _finish;
		}
		T& operator[](int pos)
		{
			assert(pos >= 0 && pos < size());
			return _start[pos];
		}
	public:
		void push_back(const T& x)
		{
			insert(end(), x);
		}
		iterator insert(iterator pos, const T& x)
		{
			if (size() >= capacity())
			{
				//扩容
				size_t offset = pos - _start;
				size_t new_capacity = (capacity() == 0) ? 1 : capacity() * 2;
				reserve(new_capacity);
				//更新失效的pos迭代器
				pos = _start + offset;
			}
			iterator end = _finish;
			while (end > pos)
			{
				*end = *(end - 1);
				end--;
			}
			*pos = x;
			++_finish;
			return pos;
		}
		iterator erase(iterator pos)
		{
			iterator p = pos;
			while (p < _finish - 1)
			{
				*p = *(p + 1);
				p++;
			}
			_finish--;
			return pos;
		}
	public:
		void swap(vector<T>& v)
		{
			std::swap(_start, v._start);
			std::swap(_finish, v._finish);
			std::swap(_end_of_storage, v._end_of_storage);
		}
		void resize(size_t n, const T& x = T())
		{
			if (n == size())
				return;
			if (n < size())
			{
				_finish = _start + n;
				return;
			}
			if (n > capacity())
				reserve(n);
			iterator it = _finish;
			_finish = _start + n;
			while (it != _finish)
			{
				*it = x;
				++it;
			}
		}
		void reserve(size_t n)
		{
			if (n > capacity())
			{
				size_t old_sz = size();
				T* new_start = new T[n];
				for (int i = 0; i < old_sz; ++i)
					new_start[i] = _start[i];
				delete[]_start;
				_start = new_start;
				_finish = _start + old_sz;
				_end_of_storage = _start + n;
			}
		}
	private:
		iterator _start;
		iterator _finish;
		iterator _end_of_storage;
	};
};
void main()
{
	bit::vector<int> iv = { 1,2,3,4,5,6,7,8,9,10 };
	for (int i = 0; i < iv.size(); ++i)
		cout << iv[i] << " ";
	cout << endl;
	cout << "size = " << iv.size() << endl;
	cout << "capacity = " << iv.capacity() << endl;
	//iv.reserve(50);
	iv.resize(20, 8);
	cout << "size = " << iv.size() << endl;
	cout << "capacity = " << iv.capacity() << endl;
	for (const auto& e : iv)
		cout << e << " ";
	cout << endl;
	
	system("pause");
}

测试结果
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值