Files
TinySTL/TinySTL/Memory.h
2015-03-15 19:03:50 +08:00

125 lines
3.0 KiB
C++

#ifndef _MEMORY_H_
#define _MEMORY_H_
#include <utility>
#include "Detail\Ref.h"
namespace TinySTL{
template<class T>
struct default_delete{
void operator ()(T* ptr){ if(ptr) delete ptr; }
};
template<class T>
struct default_delete < T[] > {
void operator ()(T* ptr){ if(ptr) delete[] ptr; }
};
template<class T, class D = default_delete<T>>
class unique_ptr{
public:
typedef T element_type;
typedef D deleter_type;
typedef element_type *pointer;
public:
explicit unique_ptr(T *data = nullptr) :data_(data){}
unique_ptr(T *data, deleter_type del) :data_(data), deleter(del){}
unique_ptr(unique_ptr&& up) :data_(nullptr){
TinySTL::swap(data_, up.data_);
}
unique_ptr& operator = (unique_ptr&& up){
if (&up != this){
clean();
TinySTL::swap(*this, up);
}
return *this;
}
unique_ptr(const unique_ptr&) = delete;
unique_ptr& operator = (const unique_ptr&) = delete;
~unique_ptr(){ clean(); }
pointer get()const{ return data_; }
deleter_type& get_deleter(){ return deleter; }
const deleter_type& get_deleter()const{ return deleter; }
operator bool()const{ return get() != nullptr; }
pointer release(){
T *p = nullptr;
TinySTL::swap(p, data_);
return p;
}
void reset(pointer p = pointer()){
clean();
data_ = p;
}
void swap(unique_ptr& up){ TinySTL::swap(data_, up.data_); }
element_type operator *()const{ return *data_; }
pointer operator ->()const{ return data_; }
private:
inline void clean(){
deleter(data_);
data_ = nullptr;
}
private:
element_type *data_;
deleter_type deleter;
};
template <class T, class D>
void swap(unique_ptr<T, D>& x, unique_ptr<T, D>& y){
x.swap(y);
}
template <class T1, class D1, class T2, class D2>
bool operator == (const unique_ptr<T1, D1>& lhs, const unique_ptr<T2, D2>& rhs){
return lhs.get() == rhs.get();
}
template <class T, class D>
bool operator == (const unique_ptr<T, D>& up, nullptr_t p){
return up.get() == p;
}
template <class T, class D>
bool operator == (nullptr_t p, const unique_ptr<T, D>& up){
return up.get() == p;
}
template <class T1, class D1, class T2, class D2>
bool operator != (const unique_ptr<T1, D1>& lhs, const unique_ptr<T2, D2>& rhs){
return !(lhs == rhs);
}
template <class T, class D>
bool operator != (const unique_ptr<T, D>& up, nullptr_t p){
return up.get() != p;
}
template <class T, class D>
bool operator != (nullptr_t p, const unique_ptr<T, D>& up){
return up.get() != p;
}
template <class T, class... Args>
unique_ptr<T> make_unique(Args&&... args){
return unique_ptr<T>(new T(std::forward<Args>(args)...));
};
template<class T>
class shared_ptr{
public:
typedef T element_type;
public:
explicit shared_ptr(T *p = nullptr) :ref_(new ref_t<T>(p)){}
template<class D>
shared_ptr(T *p, D del) : ref_(new ref_t<T>(p, del)){}
element_type* get() const{ return ref_->get_data(); }
size_t use_count() const{ return ref_->count(); }
private:
template<class Type>
using ref_t = Detail::ref_t < Type > ;
ref_t<T> *ref_;
};
}
#endif