天天看點

C++ Primer 5th筆記(chap 13 拷貝控制)阻止拷貝

對于一些類來說,拷貝操作是沒有意義的,例如 iostream 類阻止了拷貝,以避免多個對象寫入或讀取相同的 IO 緩沖。

1. 删除函數deleted function

1.1 定義

通過在函數的參數清單後面加上 =delete 函數來指明來指明這是一個删除函數,即是不能以任何方式備調用。

struct Nocopy{
	NoCopy() = default;	//預設合成構造函數
	NoCopy(const NoCopy&) = delete;	//阻止拷貝
	NoCopy& operator=(const NoCopy&) = delete;	//阻止指派
	~NoCopy() = default;	//預設合成析構函數
}
           
  • =delete 必須出現在函數第一次聲明的時候,編譯器需要知道一個函數是删除的,以便禁止它。
  • 可以對任何函數指定 =delete,但是隻能對有預設合成的函數使用 =default。
  • 析構函數不能是删除函數,否則delete 對象,局部對象析構都将error

1.2 類的成員函數是删除函數帶來的影響

如果類的某個成員的析構函數是删除函數,那麼

  • 類的合成析構函數也被定義為删除函數
  • 類的合成拷貝構造函數也被定義為删除函數

如果類的某個成員的指派運算符是是删除函數,或者類有一個 const 的引用成員,那麼

  • 類的合成拷貝指派運算符被定義為删除的
  • 或者有一個 const 成員,它沒有類内初始化器且未顯示定義預設構造函數,則該類的預設構造函數被定義為删除的。

總之,如果一個類有資料成員不能預設構造、拷貝、複制、銷毀,則對應的成員函數将被定義為删除的。

2. private 拷貝控制

新标準之前,類是通過将其拷貝構造函數和拷貝指派運算符聲明為 private 的類阻止拷貝。

class PrivateCopy{
	PrivateCopy(const PrivateCopy &);
	PrivateCopy& operator= (const PrivateCopy &);
public:
	PrivateCopy();
	~PrivateCopy();
}