joh*_*co3 6 c++ copy-constructor assignment-operator c++11
有没有办法允许移动构造函数并禁止复制构造和赋值.我可以想到几个带有文件指针和缓冲区指针(资源句柄等)的类,这些类可以从复制构造和分配中受益.
我使用的是VC2010和GCC 4.5.2.我知道我必须在VC2010类头中声明空的私有赋值和复制构造函数,据我所知,GCC允许在方法之后执行相同的操作时使用某种删除签名.
如果有人有这样一个骨架类的好例子和优点,我将非常感激.在此先感谢约翰
这是一个我希望允许移动的类的示例,但我还想阻止直接分配.这是复制构造函数和operator = private的问题吗?
class LoadLumScanner_v8002 : public ILoadLumScanner {
public:
// default constructor
LoadLumScanner_v8002();
// copy constructor
LoadLumScanner_v8002(const LoadLumScanner_v8002& rhs);
// move constructor
LoadLumScanner_v8002(LoadLumScanner_v8002&& rhs);
// non-throwing copy-and-swap idiom unified assignment
inline LoadLumScanner_v8002& operator=(LoadLumScanner_v8002 rhs) {
rhs.swap(*this);
return *this;
}
// non-throwing-swap idiom
inline void swap(LoadLumScanner_v8002& rhs) throw() {
// enable ADL (not necessary in our case, but good practice)
using std::swap;
// swap base members
// ...
// swap members
swap(mValidatedOk, rhs.mValidatedOk);
swap(mFile, rhs.mFile);
swap(mPartNo, rhs.mPartNo);
swap(mMediaSequenceNo, rhs.mMediaSequenceNo);
swap(mMaxMediaSequenceNo, rhs.mMaxMediaSequenceNo);
swap(mLoadListOffset, rhs.mLoadListOffset);
swap(mFirstLoadOffset, rhs.mFirstLoadOffset);
swap(mLoadCount, rhs.mLoadCount);
swap(mLoadIndex, rhs.mLoadIndex);
swap(mLoadMediaSequenceNo, rhs.mLoadMediaSequenceNo);
swap(mLoadPartNo, rhs.mLoadPartNo);
swap(mLoadFilePath, rhs.mLoadFilePath);
}
// destructor
virtual ~LoadLumScanner_v8002();
}
Run Code Online (Sandbox Code Playgroud)
How*_*ant 12
你提到的两种解决方案都可以正常工作.
1.
class MoveOnly
{
MoveOnly(const MoveOnly&);
MoveOnly& operator=(const MoveOnly&);
public:
MoveOnly(MoveOnly&&);
MoveOnly& operator=(MoveOnly&&);
};
Run Code Online (Sandbox Code Playgroud)
2.
class MoveOnly
{
public:
MoveOnly(const MoveOnly&) = delete;
MoveOnly& operator=(const MoveOnly&) = delete;
MoveOnly(MoveOnly&&);
MoveOnly& operator=(MoveOnly&&);
};
Run Code Online (Sandbox Code Playgroud)
"= delete"签名是C++ 11的新特性(和rvalue引用一样),与C++ 03技术基本相同(声明私有,不定义).C++ 11解决方案的优点是它肯定会在编译时捕获错误,而不是在链接时间之前延迟.
您的编译器可能还不支持"= delete",在这种情况下,您将不得不依赖第一个解决方案.
第三种解决方案是默认复制成员:
class MoveOnly
{
public:
MoveOnly(MoveOnly&&);
MoveOnly& operator=(MoveOnly&&);
};
Run Code Online (Sandbox Code Playgroud)
当声明一个move特殊成员,无论是否默认,如果你没有声明它们,编译器将隐式添加已删除的副本成员.您的编译器可能会也可能不会实现此功能.
| 归档时间: |
|
| 查看次数: |
2533 次 |
| 最近记录: |