c++ 智能指针 unique_ptr
时间: 2023-08-05 21:10:12 浏览: 142
unique_ptr 是 C++ 中的智能指针,用于管理动态分配的对象。它的特点是独占资源,即同一时间只能有一个 unique_ptr 指向同一个对象,确保了资源的独占性和自动释放。当 unique_ptr 被销毁或者重置时,它所管理的对象也会被自动释放。
unique_ptr 的使用相对简单,可以通过以下方式创建一个 unique_ptr 对象:
```
std::unique_ptr<DataType> ptr = std::make_unique<DataType>(args);
```
其中,DataType 是指向的对象类型,args 是用于构造 DataType 对象的参数。
unique_ptr 还提供了一些常用的操作方法,比如访问指针所指的对象可以使用 `*` 或者 `->` 运算符,重置指针可以使用 `reset` 方法,获取指针可以使用 `get` 方法等等。此外,unique_ptr 还支持移动语义,可以通过 `std::move` 将 unique_ptr 转移给其他 unique_ptr。
需要注意的是,unique_ptr 不支持复制语义,即不能直接进行复制操作。如果需要共享资源,可以考虑使用 shared_ptr。
相关问题
c++ 智能指针 unique_ptr实现
unique_ptr 是 C++11 中引入的智能指针,用于管理动态分配的对象。
unique_ptr 的特性是:它是唯一拥有(unique ownership)被管理对象的智能指针,也就是说,同一时间只能有一个 unique_ptr 指向一个对象。当 unique_ptr 被销毁时,它会自动释放所管理的对象内存。
下面是 unique_ptr 的简单实现:
```cpp
template <typename T>
class unique_ptr {
public:
unique_ptr(T* ptr = nullptr) : m_ptr(ptr) {}
~unique_ptr() { delete m_ptr; }
unique_ptr(const unique_ptr&) = delete;
unique_ptr& operator=(const unique_ptr&) = delete;
unique_ptr(unique_ptr&& other) noexcept : m_ptr(other.m_ptr) {
other.m_ptr = nullptr;
}
unique_ptr& operator=(unique_ptr&& other) noexcept {
if (this != &other) {
delete m_ptr;
m_ptr = other.m_ptr;
other.m_ptr = nullptr;
}
return *this;
}
T* get() const { return m_ptr; }
T* operator->() const { return m_ptr; }
T& operator*() const { return *m_ptr; }
private:
T* m_ptr;
};
```
这是一个简化版本的 unique_ptr,它包含了基本的功能,如构造函数、析构函数、移动构造函数、移动赋值运算符,以及 get()、operator->() 和 operator*() 方法。
需要注意的是,这个实现并不完整,只是为了演示 unique_ptr 的基本原理和用法。实际使用时,应该考虑更多的细节,如空指针检查、自定义删除器等。另外,C++11 中已经提供了标准库中的 unique_ptr 实现,我们通常会使用标准库中的智能指针而不是自己实现。
c++ 智能指针 unique_ptr 实现
unique_ptr 是 C++11 中引入的智能指针,用于管理动态分配的对象。它提供了独有的所有权管理,可以确保在不再需要时自动释放所管理的对象。
下面是一个简单的 unique_ptr 实现示例:
```cpp
template <typename T>
class unique_ptr {
public:
explicit unique_ptr(T* ptr = nullptr) : ptr_(ptr) {}
~unique_ptr() {
delete ptr_;
}
unique_ptr(const unique_ptr&) = delete;
unique_ptr& operator=(const unique_ptr&) = delete;
unique_ptr(unique_ptr&& other) noexcept : ptr_(other.ptr_) {
other.ptr_ = nullptr;
}
unique_ptr& operator=(unique_ptr&& other) noexcept {
if (this != &other) {
delete ptr_;
ptr_ = other.ptr_;
other.ptr_ = nullptr;
}
return *this;
}
T* get() const {
return ptr_;
}
T& operator*() const {
return *ptr_;
}
T* operator->() const {
return ptr_;
}
private:
T* ptr_;
};
```
这个简化版的 unique_ptr 实现具有基本的功能,包括构造函数、析构函数、移动构造函数、移动赋值运算符和访问底层指针的方法。请注意,这只是一个简单示例,不包含完整的异常安全和其他细节处理。在实际使用中,建议使用标准库提供的 unique_ptr。
阅读全文