2向量对象指向相同的分配内存
2 vector objects pointing to the same allocated memory
在C 中,如何制作指向相同分配内存的现有向量的副本?
例如:
vector<int> o1;
o1.push_back(1);
vector<int> o2;
//Make o2 share same memory as o1
o2[0]=2;
cout << o1[0]; //display 2
编辑:我不清楚目标:如果O1在堆上分配并被破坏,我该如何创建一个对象O2,该对象将指向与O1相同的分配内存以将其保留在O1外面范围?
使o2
引用o1
std::vector<int> &o2 = o1;
有一个boost::shared_array
模板。
但是,这共享一个固定尺寸的数据阵列,您无法修改大小。
如果要共享可重新载体的向量,则使用
boost::shared_ptr< vector< int > >
您还可以做的是swap
向量内存到其他向量。
{
std::vector< int > o1; // on the stack
// fill o1
std::vector< int > * o2 = new std::vector< int >; // on the heap
o2->swap( o1 );
// save o2 somewhere or return it
} // o2 now owns the exact memory that o1 had as o1 loses scope
C++11
将带来"移动"语义,使您可以使用std::move
保留O1中的实际记忆
std::vector<int> && foo()
{
std::vector<int> o1;
// fill o1
return std::move( o1 );
}
// from somewhere else
std::vector< int > o2( foo() );
相关文章:
- 在c++中为我自己的基于指针的数组分配内存的正确方法
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 如果 const 不分配内存,为什么我可以获取 const 的地址?
- 在函数中分配内存时出现问题
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- constexpr new 如何分配内存?
- 在构造函数中分配内存失败是如何冒泡的
- LLVM 传递以在特定地址分配内存
- CudaMalloc 在分配内存时失败
- 为什么它在不分配内存的情况下工作正常
- 为什么在正确解除分配内存时出现内存泄漏?
- 如何通过 malloc 为队列数组分配内存?
- vector是否为std::移动的对象连续分配内存
- 删除类成员的动态分配内存的最佳方法是什么
- 唯一指针是否在堆或堆栈上分配内存?
- 如果不分配内存,我如何能够为变量创建和分配值?
- std::initializer_list 堆是否分配内存?
- 如何按顺序或在指定的地址分配内存?
- 是否可以使用 malloc 为类对象分配内存?
- 迭代器是否分配内存(如指针)?