C++模板编程练习--实现一个简单的顺序容器vector

实现C++ STL里面的一个顺序容器vector

在这里插入图片描述

如上图所示,vector底层维护的也是一个数组,使用3个指针:

  • _first:指向数组的起始位置
  • _last:指向数组中有效元素的后继位置
  • _end: 指向数组空间的后继位置

不添加空间配置器,简单实现vector容器

#include <iostream>

template<typename T>
class Vector 
{
public:
	// 构造函数
	Vector(int size=10) {
		_first = new T[size];
		_last = _first;
		_end = _first + size;
	}

	// 析构函数
	~Vector() {
		delete[]_first;
		_first = _last = _end = nullptr;
	}

	// 拷贝构造函数,进行深拷贝(注意:拷贝构造对象,函数体中当然没有释放当前资源,毕竟对象还没构造,哪来的资源释放)
	Vector(const Vector<T>& src) {
		int size = src._end - src._first;		// 容器容量
		int len = src._last - src._first;		// 元素个数
		_first = new T[size];
		for (int i = 0; i < len; ++i) {
			_first[i] = src._first[i];
		}
		_last += len;
		_end += size;
	}

	// 赋值重载函数
	Vector<T>& operator=(const Vector<T>& src) {
		// 防止自赋值
		if (this == &src)
			return *this;
		// 释放当前对象占用的外部资源
		delete[]_first;
		// 执行深拷贝	
		int size = src._end - src._first;		// 容器容量
		int len = src._last - src._first;		// 元素个数
		_first = new T[size];
		for (int i = 0; i < len; ++i) {
			_first[i] = src._first[i];
		}
		_last += len;
		_end += size;
	}

	// 容器末尾添加元素
	void push_back(const T& val) {
		if (full())
			expand();
		*_last = val;
		_last++;
	}

	// 从容器末尾删除元素
	void pop_back() {
		if (empty())
			return;
		--_last;
	}

	// 获取容器末尾元素
	T back() const {
		return *(_last - 1);
	}
	
	// 判满函数
	bool full() { return _last == _end; }
	// 判空函数
	bool empty() { return _first == _last; }

private:
	// 二倍扩容函数
	void expand() {
		int size = _end - _first;
		T* ptmp = new T[2 * size];
		for (int i = 0; i < size; ++i) {
			ptmp[i] = _first[i];
		}
		delete[]_first;
		_first = ptmp;
		_last = _first + size;
		_end = _first + 2 * size;
	}
private:
	T* _first;			// 指向数组的起始位置
	T* _last;			// 指向数组中最后一个元素的后继位置
	T* _end;			// 指向数组空间的后继位置
};
int main() {
	Vector<int> vec;
	for (int i = 0; i < 20; ++i) {
		vec.push_back(rand() % 100 + 1);
	}

	while (!vec.empty()) {
		std::cout << vec.back() << " ";
		vec.pop_back();
	}
	std::cout << std::endl;
	
	return 0;
}

在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

下酒番陪绅士

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值