C++中emplace函数的不适场景总结(三)

可能产生的内存泄露

上文中一直考虑 vector 扩容的情况。现在来分析一下,有下面一份代码:

复制代码
#include <memory>
#include <string>
#include <vector>

int main() {
    std::vector<std::shared_ptr<std::string>> arr;
    // todo

    std::string str("Hello World");
    arr.push_back(std::shared_ptr<std::string>(new std::string(str)));
    arr.emplace_back(new std::string(str));
}

此处的 todo 可能对 arr 做了一些操作,而到了 push_back() 和 emplace_back() 的两行中都会进行插入操作。

假设两处的插入操作都有扩容的可能,也就是说在此处会有新的内存分配可能。一旦涉及到内存的分配都有可能会出现异常或者其他情况。

假设 push_back() 处因为内存分配出现了异常,则作为参数的 std::shared_ptr<std::string>(new std::string(str)) 因为已经是一个智能指针的对象了,可以借助 RAII 的特性成功的回收管理 new 出来的内存。

而假设 emplace_back() 处因为内存分配出现了异常,则由于 new 出来的参数是一个裸指针,这块内存将再也无法回收,也就是直接内存泄漏了。

因为请勿直接传递裸指针到 emplace() 函数中。

总结与建议

关于 emplace() 的优势必然是 原位构造。而劣势也就是无法进行原位构造。

因此在编程时需要在保证内存不会泄露的情况下,了解各种容器对于原生的插入操作和 emplace() 操作的性能差别。

除了本文中直接给出的示例,还可以通过一些代码分析工具去分析。刷题党甚至可以通过交替使用 emplace() 和 push()/insert() 操作进行提交,根据 oj 的返回结果进行规律的分析。

相关推荐
To_OC11 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户9385156350716 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC17 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥17 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者19 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者19 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月1 天前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星1 天前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星1 天前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试