標籤:opera int include 對象 報錯 問題 繼承 ring public
練習13.6
其實就是“=”運算,也就是賦值運算。右側運算對象作為顯示參數向左側傳遞時時候。合成拷貝賦值運算子來禁止該類型對象的賦值。當一個類沒有定義自己的拷貝賦值運算子的時候,編譯器會為它自動產生一個合成拷貝賦值運算子。
練習13.7
將一個StrBlob賦值給另一個StrBlob這個操作是完全沒有問題的。
當賦值StrBlobPtr的時候就會出錯,在編譯的時候就會報錯,左右值的類型不一樣(也不是繼承關係),無法完成賦值。
練習13.8
1 #include <iostream> 2 #include <string> 3 #include <memory> 4 5 using namespace std; 6 7 8 class HasPtr { 9 friend ostream &print(ostream &os, HasPtr &h);10 public:11 HasPtr(const string &s = string()) : ps(new string(s)), i(0) {}12 HasPtr(const HasPtr &ptr);13 HasPtr &operator=(const HasPtr &pt);14 private:15 string *ps;16 int i;17 };18 19 ostream &print(ostream &os, HasPtr &h);20 21 int main()22 {23 HasPtr has("hello");24 HasPtr have = has;25 print(cout, have);26 system("pause");27 return 0;28 }29 30 HasPtr::HasPtr(const HasPtr & ptr) : ps(new string(*(ptr.ps))),i(ptr.i) {}31 32 HasPtr & HasPtr::operator=(const HasPtr & pt)33 {34 ps = new string(*pt.ps);35 i = pt.i;36 return *this;37 // TODO: 在此處插入 return 語句38 }39 40 ostream & print(ostream & os, HasPtr & h)41 {42 os << *h.ps << h.i << endl;43 return os;44 // TODO: 在此處插入 return 語句45 }
C++primer 13.1.2節練習