为什么 std::move 的行为类似于 std::copy
why std::move behaves like std::copy?
考虑以下一段代码 -
#include <algorithm>
#include <iostream>
#include <vector>
int main()
{
std::vector<int> d {100, 200, 300};
std::vector<int> l {1, 2, 3, 4, 5};
std::move(d.begin(), d.end(), std::inserter(l, l.begin()));
for (int n : l) std::cout << n << ' ';
std::cout << 'n';
for (int n : d) std::cout << n << ' ';
std::cout << 'nn';
for (int &n : d) n +=5;
for (int n : l) std::cout << n << ' ';
std::cout << 'n';
for (int n : d) std::cout << n << ' ';
std::cout << 'n';
}
此处插入了原始std::vector l
,其中包含移动操作后std::vector d
的内容。我知道所有已从中移动的标准库对象都处于有效但未指定的状态,但是,我很想进一步移动并检查值。在移动操作之后,std::vector d
的值仍然保持不变,这可以证明好像两者都引用相同的数据位置一样合理?同样,当我尝试修改这些值时,更改不会反映在新std::vector l
容器中。
这是输出 -
100 200 300 1 2 3 4 5 100 200 300 100 200 300 1 2 3 4 5 105 205 305
似乎这些值是从源容器复制到目标容器的,并且源容器可以保留原始内容。这听起来不像是std::copy
操作吗?
对于普通的旧数据,移动和复制是相同的。除了复制之外,没有其他方法可以移动普通数据。例如,如果您拥有其他一些对象的所有权,这些对象可以在不复制的情况下转移(如std::string
或std::shared_ptr
),情况就不同了。但对于int
来说,这并不适用。
相关文章:
- 类似于strcat()的函数出现问题
- 对于多个字符(如 ETX/STX 对),是否有类似于 std::quote 的东西
- C++类似于 std::map 的数据结构,具有多个键级别
- 就地合并,类似于 std::vector 中的元素
- 使结构的行为类似于 std::tuple
- C99 中的_Complex类型在 C++ 中的行为是否类似于 std::complex<>?
- 创建一个类似于 std::integral_constant 的容器
- 为什么 std::move 的行为类似于 std::copy
- 类似于类中的 std::map 或 std::vector 的构造函数
- 为什么我需要一个类似于复合文字的临时构造来初始化我的std::数组成员
- C++类似于 std::vector / boost::array 的文件内存映射容器
- 将字符串的向量连接到std::ostream(类似于boost::Join)
- 为什么std::字符串串联运算符的工作原理类似于右关联运算符
- 为什么 std::生成类似于 std::for_each 的返回状态?
- 类似于' std::set_intersection ',但产生相等的元素对
- 对于std::tr1::unordered_map,是否存在类似于std::map::lower_bound的等效std
- 是否有std::函数类型或类似于带有auto参数的lambda
- 如何实现类似于 std::vector 的自定义类
- 是std::unordered_set连续的(类似于std::vector)
- 传递一个成员函数,类似于c++中的std::函数(类似于c#)