c++学习笔记(7)——关于类的实现(以vector为例)

#ifndef VEC_H
#define VEC_H

#pragma warning(disable:4996)//这里最好有这一句,否则uninitialized_copy 函数会被称为unsafe!也提示我们在出现unsafe的时候,要用这个屏蔽掉。
#include <iostream>
#include <algorithm>
#include <memory>


template <class T>
class Vec
{
public:

	typedef T*				iterator;
	typedef const T*		const_iterator;
	typedef size_t			size_type;
	typedef T				value_type;
	typedef std::ptrdiff_t	difference_type;
	typedef T&				reference;
	typedef const T&		const_reference;


	Vec() { create(); }
	explicit Vec(std::size_t n, const T& val = T()) { create(n, val); }	
	Vec(const Vec& v) { create(v.begin(), v.end()); }
	Vec& operator= (const Vec&);
	~Vec() { uncreate(); }


	T& operator[] (size_type i) { return data[i]; }
	const T& operator[] (size_type i) const { return data[i]; }

	void push_back(const T& val)
	{
		if (avail == limit)
			grow();
		unchecked_append(val);
	}

	size_type size() const { return avail - data; }

	iterator begin() { return data; }
	const iterator begin() const { return data; }

	iterator end() { return avail; }
	const iterator end() const { return avail; }

	bool empty() const { return data == limit; }

	//iterator erase(iterator);
	
	void clear() { uncreate(); }
	

private:
	iterator data;
	iterator avail;
	iterator limit;

	std::allocator<T> alloc;//这里一定要加std!!alloc方面的都是需要std的!

	void create();
	void create(size_type, const T&);
	void create(const_iterator, const_iterator);

	void uncreate();

	void grow();
	void unchecked_append(const T&);

};



template <class T>
void Vec<T>::create()
{
	data = avail = limit = 0;
}

template <class T>
void Vec<T>::create(size_type n, const T& val)
{
	data = alloc.allocate(n);
	limit = avail = data + n;
	uninitialized_fill(data, limit, val);
}

template<class T>
void Vec<T>::create(const_iterator i, const_iterator j)
{
	data = alloc.allocate(j - i);
	limit = avail = uninitialized_copy(i, j, data);
}

template <class T>
void Vec<T>::uncreate()
{
	if (data)
	{
		iterator it = avail;
		while (it != data)
			alloc.destroy(--it);

		alloc.deallocate(data, limit - data);
	}

	data = limit =  avail = 0;
}



template <class T>
void Vec<T>::grow()
{
	size_type new_size = max(2 * (limit - data), ptrdiff_t(1));

	iterator new_data = alloc.allocate(new_size);
	iterator new_avail = uninitialized_copy(data, avail, new_data);

	uncreate();

	data = new_data;
	avail = new_avail;
	limit = data + new_size;
}

template <class T>
void Vec<T>::unchecked_append(const T& val)
{
	alloc.construct(avail++, val);
}


template <class T>
Vec<T>& Vec<T>::operator= (const Vec& rhs)
{
	if (&rhs != this)
	{
		uncreate();
		create(rhs.begin(), rhs.end());
	}
	return *this;
}


#endif

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值