std::shared_ptr<std::vector有什么问题<double>>
what's wrong in std::shared_ptr<std::vector<double>>
我的印象是 std::shared_ptr 在超出范围时不会释放内存。下面是我的测试代码。你能告诉我我做错了什么吗?我使用 gtest 进行测试。当我执行此测试时,我可以看到内存不断消耗。我使用 VC++ 2013 Microsoft。
void ProceedVector() {
std::vector<double> * numbers = new std::vector<double>();
for (int ind = 0; ind != 10000; ind++) {
numbers->push_back(ind);
}
std::shared_ptr<std::vector<double>> numbersPtr = std::make_shared<std::vector<double>>(*numbers);
}
TEST_F(ManagerTypeConvertorTest, ProceedVector) {
for (int ind = 0; ind != 50000; ind++) {
ProceedVector();
}
}
每次调用ProceedVector
都会对std::vector<double>
对象进行两次动态分配。一个在这里:
std::vector<double> * numbers = new std::vector<double>();
另一个在这里:
std::shared_ptr<std::vector<double>> numbersPtr = std::make_shared<std::vector<double>>(*numbers);
make_shared
并不意味着"将此对象分配给shared_ptr
"。它的意思是"从这些参数分配一个新对象,并使用shared_ptr
管理新分配的对象 "。
根据您希望代码实现的目标,将new
行替换为make_shared
行并且根本不使用原始指针,或者将make_shared
行替换为以下内容:
std::shared_ptr<std::vector<double>> numbersPtr{numbers};
这将构造一个shared_ptr
,该将管理numbers
指向的内存。
您有两个指向两个不同向量的指针:
-
一个将被删除的指针(包含来自第一个向量的内容副本的共享指针(
-
还有一个不会被删除的(你用
new
创建的第一个向量(。
相关文章:
- 使用std::multimap迭代器创建std::list
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 从持续时间构造std::chrono::system_clock::time_point
- std::具有相同基类的类的变体
- std::向量与传递值的动态数组
- 使用std::vector的OpenCL矩阵乘法
- std::map<struct,struct>::find 找不到匹配项,但是如果我循环通过 begin() 到 end(),我在那里看到匹配项
- std::condition_variable::wait()如何评估给定的谓词
- 如何获取std::result_of函数的返回类型
- std::原子加载和存储都需要吗
- 将对象移动到std::shared_ptr
- std::vector<;uint8_t>;当C++11/14启用时,手动复制而不是调用memcpy
- 是std :: set&lt; std :: future&gt;不可能存在
- 在修改列表后,std :: list&lt; t&gt; :: end()的值是否会更改
- 使用 std::vector<boost::shared_ptr<Base_Class>> 或 boost::p tr_vector 的性能注意事项是什么<Base>
- std::map<std::set, double> AND std:<long>map< std::p air<long, long>, double>
- 如何获取std::vector<DMatch>