常见错误是只删了拷贝构造函数,却忘了拷贝赋值运算符。C++11 起,delete 一个不等于自动禁用另一个——两者必须都显式删除,否则编译器会生成默认的拷贝赋值函数,导致“看似不可拷贝实则可赋值”。
C++如何实现不可拷贝类?(delete拷贝构造函数)
常见错误是只删了拷贝构造函数,…
技术博客
常见错误是只删了拷贝构造函数,却忘了拷贝赋值运算符。C++11 起,delete 一个不等于自动禁用另一个——两者必须都显式删除,否则编译器会生成默认的拷贝赋值函数,导致“看似不可拷贝实则可赋值”。
直接写 using 比 typedef 更直观,尤其面对模板时不会绕晕。比如想给 std::vector<int></int> 起个短名叫 IntVec,就这么写:
它不复制、不移动内存,只是把一个左值强制转成右值引用类型,让编译器“相信”你可以搬走它。本质是类型转换函数,返回 static_cast<t>(t)</t>。
写 Python 时把 = 当成“等于”来用,是新手最常触发 SyntaxError 或逻辑错误的源头。它只做一件事:把右边的值绑定给左边的变量名,不返回布尔值,也不能用于条件判断或循环条件中。
移动语义的核心目标,是用“搬走资源”代替“复制资源”,从而避免深拷贝开销。关键不在于写几个 std::move,而在于识别可移动的右值、正确声明移动构造函数/移动赋值运算符,并让编译器有机会自动调用它们。