如何把static std::unique_ptr<uint8_t[]> new_extradata(new uint8_t[new_extradata_size]); 赋值给cp->extradata 一份,并保证不被覆盖
时间: 2024-03-02 09:52:37 浏览: 49
如果想要将 `new_extradata` 赋值给 `cp->extradata`,并保证不被覆盖,可以使用以下代码:
```
cp->extradata = std::move(new_extradata);
```
这里使用了 `std::move` 将 `new_extradata` 的所有权转移给了 `cp->extradata`,这样做可以保证不会发生内存泄漏或者多次释放同一块内存的情况。
另外需要注意的是,在赋值之前需要确保 `cp->extradata` 指针原来指向的内存已经被释放,否则会导致内存泄漏。
相关问题
static std::unique_ptr<uint8_t[]> new_extradata;如何初始化
在 C++11 中,你可以使用以下方式初始化 `std::unique_ptr`:
1. 使用 `new` 运算符手动分配内存,并将返回的指针传递给 `std::unique_ptr` 的构造函数:
```cpp
static std::unique_ptr<uint8_t[]> new_extradata(new uint8_t[1024]);
```
这里我们手动分配了 1024 字节的内存,并将返回的指针传递给 `new_extradata` 的构造函数,使得 `new_extradata` 管理这段内存。需要注意的是,`std::unique_ptr` 会默认使用 `delete[]` 来释放数组类型的内存,因此不需要指定删除器。
2. 使用 `std::make_unique` 函数:
```cpp
static auto new_extradata = std::make_unique<uint8_t[]>(1024);
```
这里我们使用 `std::make_unique` 函数来创建一个 `std::unique_ptr` 对象,并初始化为一个 `uint8_t` 类型的数组。需要注意的是,这里需要指定数组的大小,即 `1024`。
C++ 11 如何改写 static std::unique_ptr<uint8_t[]> new_extradata;
在 C++11 中使用 `unique_ptr` 时需要显式指定删除器(deleter),因为 C++11 中的 `unique_ptr` 不支持默认删除器。你可以像下面这样修改代码:
```cpp
static std::unique_ptr<uint8_t[], std::default_delete<uint8_t[]>> new_extradata;
```
其中,`std::default_delete<uint8_t[]>` 是 `unique_ptr` 的默认删除器,用于释放动态分配的数组内存。你也可以提供自己的删除器,例如:
```cpp
void my_deleter(uint8_t* p)
{
// 自定义的删除器
delete[] p;
}
static std::unique_ptr<uint8_t[], void(*)(uint8_t*)> new_extradata(nullptr, my_deleter);
```
这里,我们提供了一个自定义的删除器 `my_deleter`,它接受一个 `uint8_t*` 类型的指针,并使用 `delete[]` 将其释放。第二个模板参数是一个函数指针类型,用于存储删除器。需要注意的是,函数指针类型的参数需要指定函数指针的类型,即 `void(*)(uint8_t*)`。