C++ 11 如何改写 static std::unique_ptr<uint8_t[]> new_extradata;
时间: 2024-03-02 07:50:26 浏览: 21
在 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*)`。
相关问题
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++中 std::unique_ptr<uint8_t[]> new_extradata;如何初始化
要初始化一个 `std::unique_ptr<uint8_t[]>` 对象,可以使用 `std::make_unique` 函数。例如,可以这样初始化 `new_extradata`:
```
new_extradata = std::make_unique<uint8_t[]>(size);
```
其中,`size` 是一个 `size_t` 类型的变量,表示分配的内存块的大小。这个语句会自动分配一个 `size` 大小的内存块,并将返回的指针包装在 `std::unique_ptr` 对象中。如果 `new_extradata` 已经包含了一个指针,那么它会自动释放它指向的内存块。