-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMyUniquePtr.cpp
More file actions
80 lines (77 loc) · 1.92 KB
/
MyUniquePtr.cpp
File metadata and controls
80 lines (77 loc) · 1.92 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#include <algorithm>
#include <cstddef>
#include <memory>
#include <tuple>
template<typename T, typename Deleter = std::default_delete<T>>
class UniquePtr {
private:
std::tuple<T*, Deleter> unptr;
T* ptrG() const {
return std::get<0>(unptr);
}
Deleter dltrG() const {
return std::get<1>(unptr);
}
T*& ptrG() {
return std::get<0>(unptr);
}
Deleter& dltrG() {
return std::get<1>(unptr);
}
public:
UniquePtr(T* ptr = nullptr, const Deleter& deleter = Deleter()) noexcept
: unptr(std::make_tuple(ptr, deleter)) {}
UniquePtr(UniquePtr&& other) noexcept : unptr(other.unptr) {
other.ptrG() = nullptr;
}
~UniquePtr() {
dltrG()(ptrG());
}
UniquePtr(const UniquePtr& other) = delete;
UniquePtr& operator=(const UniquePtr& other) = delete;
UniquePtr& operator=(std::nullptr_t) noexcept {
dltrG()(ptrG());
ptrG() = nullptr;
return *this;
}
UniquePtr& operator=(UniquePtr&& other) noexcept {
if (ptrG() != other.ptrG()) {
dltrG()(ptrG());
unptr = other.unptr;
other.ptrG() = nullptr;
}
return *this;
}
T& operator*() const noexcept {
return *ptrG();
}
T* operator->() const noexcept {
return ptrG();
}
T* release() noexcept {
T* old = ptrG();
ptrG() = nullptr;
return old;
}
void reset(T* ptr) noexcept {
if (ptrG() != ptr) {
dltrG()(ptrG());
ptrG() = ptr;
}
}
void swap(UniquePtr& other) noexcept {
std::swap(unptr, other.unptr);
}
T* get() const noexcept {
return ptrG();
}
explicit operator bool() const noexcept {
return (ptrG() != nullptr);
}
Deleter& get_deleter() noexcept {
return dltrG();
}
const Deleter& get_deleter() const noexcept {
return dltrG();
}
};