首页 > 后端开发 > C++ > 正文

c++中的std::uninitialized_copy和std::uninitialized_fill_c++高效操作未初始化内存

尼克
发布: 2025-12-05 15:38:02
原创
839人浏览过
std::uninitialized_copy和std::uninitialized_fill用于在未初始化内存中构造对象,前者复制范围内的对象调用拷贝构造函数,后者填充相同值并调用构造函数,避免对未构造内存赋值导致的未定义行为,需手动析构并释放内存,适用于底层高性能场景。

c++中的std::uninitialized_copy和std::uninitialized_fill_c++高效操作未初始化内存

在C++中处理未初始化的原始内存时,直接使用构造对象是不安全的。标准库提供了 std::uninitialized_copystd::uninitialized_fill 来安全、高效地在未初始化内存上构造对象。它们与普通的 copyfill 不同:不是赋值,而是调用对象的构造函数。

std::uninitialized_copy:从范围构造对象

当你有一段已分配但未初始化的内存(例如通过 operator newstd::allocator::allocate),并希望将某个范围的对象“复制”到这块内存中,这时应使用 std::uninitialized_copy

它会逐个在目标位置调用拷贝构造函数,而不是赋值操作。

template
  ForwardIt uninitialized_copy(InputIt first, InputIt last, ForwardIt d_first);

示例:

立即学习C++免费学习笔记(深入)”;

#include
#include
#include iostream>

int main() {
  std::string arr[] = {"hello", "world"};
  void* buf = operator new(2 * sizeof(std::string));
  std::string* p = static_cast<:string>(buf);

  // 在 buf 指向的内存中构造两个字符串
  auto fin = std::uninitialized_copy(arr, arr + 2, p);

  for (std::string* it = p; it != fin; ++it) {
    std::cout   }
  std::cout
  // 手动析构
  for (std::string* it = p; it != fin; ++it) {
    it->~basic_string();
  }
  operator delete(buf);
  return 0;
}

注意:必须手动调用析构函数,并使用 operator delete 释放原始内存。

std::uninitialized_fill:填充相同值

当你要在未初始化内存中构造多个相同的对象时,使用 std::uninitialized_fill

它会在指定范围内对每个元素调用给定值的拷贝构造函数。

Red Panda AI
Red Panda AI

AI文本生成图像

Red Panda AI 74
查看详情 Red Panda AI
template
  void uninitialized_fill(ForwardIt first, ForwardIt last, const T& value);

示例:

立即学习C++免费学习笔记(深入)”;

#include
#include
#include stream>

int main() {
  void* buf = operator new(3 * sizeof(std::string));
  std::string* p = static_cast<:string>(buf);

  std::uninitialized_fill(p, p + 3, "default");

  for (int i = 0; i     std::cout   }
  std::cout
  // 析构
  for (int i = 0; i     p[i].~basic_string();
  }
  operator delete(buf);
  return 0;
}

为什么不能用普通 copy/fill?

普通 std::copystd::fill 假设目标内存已经构造了对象,它们执行的是赋值操作(operator=)。对未构造的对象赋值会导致未定义行为。

uninitialized_* 系列函数则确保调用的是构造函数,适用于原始内存场景。

现代替代方案:std::vector 和智能指针

虽然这些函数在实现容器或内存池时很有用,但在日常代码中,推荐使用 std::vectorstd::make_unique 等 RAII 工具来自动管理构造和析构。

例如,用 std::vector<:string></:string> 替代手动内存管理更安全简洁。

基本上就这些。理解 uninitialized_copyuninitialized_fill 的作用,有助于编写高效且正确的底层内存操作代码,尤其是在自定义容器或高性能库中。关键是:构造 vs 赋值,别搞混。

以上就是c++++中的std::uninitialized_copy和std::uninitialized_fill_c++高效操作未初始化内存的详细内容,更多请关注php中文网其它相关文章!

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号