作者热门文章
- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
正如您在输出中看到的, vector pre
的对象不仅“move ”到 vector post
,而且还在内存中保留了它们的原始地址空间.此举背后究竟发生了什么?这种行为是预期的吗?假设我需要一个单独的指向这些对象的指针 vector ,是否可以安全地假设在此 move 之后对象将始终具有其原始地址?
实际上,我有一个包含这样的 vector 和我作为成员提到的指针 vector 的类。我还删除了复制 ctors,并为类定义了 move ctors。
#include <iostream>
#include <vector>
struct B {
int val = 0;
B(int aInt) : val(aInt) { };
};
int main() {
std::vector<B> pre;
pre.push_back(B(1));
pre.push_back(B(2));
std::cout << "pre-move:\t" << (void*)&pre.at(0) << '\n';
std::cout << "pre-move:\t" << (void*)&pre.at(1) << '\n';
std::vector<B> post(std::move(pre));
std::cout << "post-move:\t" << (void*)&post.at(0) << '\n';
std::cout << "post-move:\t" << (void*)&post.at(1) << '\n';
return 0;
}
输出:
pre-move: 0x1d7b150
pre-move: 0x1d7b154 <------|
post-move: 0x1d7b150 |
post-move: 0x1d7b154 <------|
最佳答案
vector 基本上只不过是指向堆分配内存的指针、 vector 的当前长度和当前容量。
通过“move ”一个 vector ,您所做的只是复制这些值,并重置移出的 vector 的值。
对于vector的数据,基本等同于
original_pointer = some_place_in_memory;
new_pointer = original_pointer; // Copies the *value* of original_pointer
original_pointer = nullptr;
无需分配新内存和复制 vector 中的数据。
关于c++ - vector 元素如何在 vector std::move 之后保留其原始地址?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53904835/
我是一名优秀的程序员,十分优秀!