使用智能指针管理函数内分配的内存
Using a smart pointer to manage memory allocated within function
背景
如果我有一个函数foo
,如下
void foo(std::vector<int>& values)
{
values = std::vector<int>(10, 1);
}
然后我可以称之为
std::vector<int> values;
foo(values);
请注意,初始vector
为空,然后在函数foo
中填充它。
我经常遇到无法更改的接口(即第三方),它们与上面的意图相同,但使用原始数组,例如
void foo(int*& values)
{
values = new int[10];
std::fill_n(values, 10, 1);
}
我的问题是,现在我负责管理内存,例如
int* values;
foo(values);
delete[] values;
问题
有什么方法可以让我使用智能指针来管理我的内存吗?我想做一些类似的事情
std::unique_ptr<int[]> values;
foo(values.get());
但是get
返回的指针是r值,所以我不能通过非常数引用传递它。
- 创建空的unique_ptr
- 创建指针
- 将指针传递给函数
- 将unique_ptr重置为该指针
比如:
std::unique_ptr<int[]> values;
int* values_ptr;
foo(values_ptr);
values.reset(values_ptr);
或者:
int* values_ptr;
foo(values_ptr);
std::unique_ptr<int[]> values(values_ptr);
简单的答案:你不能。但我相信有一种方法可以简化你的生活。由于你总是做同样的事情,你只需要编写一个函数来为你做这件事,并在需要时调用该函数。因为我想你想在释放之前使用写在内存中的返回值,所以我让我的函数返回它
template <typename T, typename Function>
std::unique_ptr<T[]> call(Function f) {
T * value;
f(value);
return { value };
}
// then to use it
auto value = call<int>(foo);
这适合你吗?
如果需要,可以改进该函数来检测指向一个对象或数组的指针的差异,也可以改进它来自动检测所需的参数类型,这样您就不必键入它。
相关文章:
- 在c++中为我自己的基于指针的数组分配内存的正确方法
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 如果 const 不分配内存,为什么我可以获取 const 的地址?
- 在函数中分配内存时出现问题
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- constexpr new 如何分配内存?
- 在构造函数中分配内存失败是如何冒泡的
- LLVM 传递以在特定地址分配内存
- CudaMalloc 在分配内存时失败
- 为什么它在不分配内存的情况下工作正常
- 为什么在正确解除分配内存时出现内存泄漏?
- 如何通过 malloc 为队列数组分配内存?
- vector是否为std::移动的对象连续分配内存
- 删除类成员的动态分配内存的最佳方法是什么
- 唯一指针是否在堆或堆栈上分配内存?
- 如果不分配内存,我如何能够为变量创建和分配值?
- std::initializer_list 堆是否分配内存?
- 如何按顺序或在指定的地址分配内存?
- 是否可以使用 malloc 为类对象分配内存?
- 迭代器是否分配内存(如指针)?