考虑这段代码:
#include <iostream>
using namespace std;
void Func(int&& i) {
++i;
}
int main() {
int num = 1234;
cout << "Before: " << num << endl;
Func(std::move(num));
cout << "After: " << num << endl;
}
它的输出是:
Before: 1234
After: 1235
显然,i
在内部被修改Func
,因为它i
在被“转换”为 r 值引用后绑定到参数std::move
。
好吧,我的观点:
移动对象意味着将资源的所有权从一个对象转移到另一个对象。但是,内置类型不包含资源,因为它们本身就是资源。转移他们持有的资源是没有意义的。如示例所示,num
的值被修改。它的资源,它的自身,是被修改的那个。
内置类型是否具有移动语义?
另外,移动后的内置类型对象(如果是的话)是明确定义的行为吗?