生活随笔
收集整理的這篇文章主要介紹了
赋值运算符函
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1. 賦值運算符的重載函數的聲明,需要返回類型的引用,也就是CMyString& ,這里是為了考慮到形如 a = b = c這樣的連續賦值操作,因此需要在函數結束前加上return *this;
2. 函數傳參需要引用,這樣避免了調用一次拷貝構造函數提高效率,同時為了不改變傳入實例,需要加上const
3. 重新分配內存時候,必須要釋放之前自己已有的空間,否則會導致內存泄漏
4. 要考慮到自己賦值給自己,即this == &other時候,其實不需要執行任何操作,同時更為重要的是:對于我自己寫的代碼如果不加上if (this != &other)代碼就是錯的,因為我是先釋放內存再根據other需要的空間開辟一塊新空間,對于自己賦值給自己的情況,由于已經自己指向的那塊空間已經釋放了,所以再也找不到需要賦值的內容了。
#include <iostream>
#include <cstring>
using namespace std;class String
{public:String(const char *s=nullptr);
//自定義構造函數 String(
const String &s1);
//拷貝構造哈數 String &
operator=(
const String &s);
//賦值構造函數 void print();private:char *
data;
};String::String(const char *
s)
{if(s==
NULL){data=
new char[
1];data[0]=
'\0';}else{data=
new char[strlen(s)+
1];strcpy(data,s);}
}String::String(const String &
s1)
{ data=
new char[strlen(s1.data)+
1];strcpy(data,s1.data);//cout<<" copy."<<endl;
}String &String::
operator=(
const String &
s)
{if(&s==
this)
//防止自己賦值 return *
this;delete []data;data=
new char[strlen(s.data)+
1];strcpy(data,s.data);//cout<<" operator=."<<endl;
}void String::print()
{cout<<data<<
endl;
}int main()
{String s("hello word.");
//自定義構造函數 String s2=s;
//拷貝構造函數 String s3(s2);
//s3需要用s2初始化,調用拷貝構造函數 s2=s3;
//s2,s3已存在。調用賦值構造函數 ;當一個類的對象向該類的另一個對象賦值時,就會用到該類的賦值函數。首先該對象要存在
s2.print();s3.print();return 0;
} ?
轉載于:https://www.cnblogs.com/tianzeng/p/10072305.html
總結
以上是生活随笔為你收集整理的赋值运算符函的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。