為了能進行類物件和一個整型值的加法運算,需要寫一個類的成員函式來過載雙目加法(+)運算子。以下是本站小編搜尋整理的計算機二級考試複習資料:C++過載雙目運算子,供參考複習,希望對大家有所幫助!想了解更多相關資訊請持續關注我們應屆畢業生考試網!
一、作為類成員函式的過載
為了能進行類物件和一個整型值的加法運算,需要寫一個類的成員函式來過載雙目加法(+)運算子。該函式在類中的宣告如下:
Date operator + (int) const;
函式的宣告指出,返回值是一個Date類物件,函式名是運算子+,只有一個整型引數,而且函式是常量型的。當編譯器發現某個函式以加上字首operator的真實運算子作為函式名,就會把該函式當作過載運算子函式來處理。如果在表示式中,該運算子的左邊是一個類物件,右邊是一個引數型別的`一個物件,那麼過載運算子函式就會被呼叫。
呼叫形式如下:
Date dt(6,9,2005);
dt=dt+100;
也可以顯式的呼叫過載運算子函式:
ator + (100);
下面程式碼過載了雙目加法運算子來計算一個整數和一個Date類物件之和,並且返回Date類物件。
#include iostream.h
class Date
{
int mo,da,yr;
static int dys[];
public:
Date(int m=0,int d=0,int y=0)
{ mo=m; da=d; yr=y;}
void display() const
{ cout < Date operator + (int) const;
};
int Date::dys[]={31,28,31,30,31,30,31,31,30,31,30,31};
Date Date::operator+(int) const
{
Date dt=*this;
n+=;
while(n >=dys[-1])
{
n-=dys[-1];
if(++==13)
{
=1;
dt,yr++;
}
}
=n;
return dt;
}
int main()
{
Date olddate(1,1,2005);
Date newdate;
newdate=olddate+100;
lay();
return 0;
}
二、非類成員的運算子過載
在過載運算子的原則中說到,要保持運算子的可交換性。而上面的程式只允許Date類物件在運算子的左邊而整型值在右邊,不支援下面的語句:
Date newdate=100+olddate;
所以,僅僅靠一個類的成員過載運算子是無法實現上面功能的。對過載雙目運算子的類成員函式來說,總是認定呼叫函式的物件位於運算子左邊。不過,我們可以再寫一個非類成員的過載運算子函式,可以規定Date類的物件在運算子右邊,而別的型別在運算子左邊。例如,我們可以這樣在類的外部定義一個函式:
Date operator + (int n,Date & dt)
下面程式碼在原先的基礎上增加了一個非類成員函式來實現雙目加法運算子的過載。
#include iostream.h
class Date
{
int mo,da,yr;
static int dys[];
public:
Date(int m=0,int d=0,int y=0)
{ mo=m; da=d; yr=y;}
void display() const
{ cout < Date operator + (int) const;
};
int Date::dys[]={31,28,31,30,31,30,31,31,30,31,30,31};
Date Date::operator+(int) const
{
Date dt=*this;
n+=;
while(n >=dys[-1])
{
n-=dys[-1];
if(++==13)
{
=1;
dt,yr++;
}
}
=n;
return dt;
}
Date operator + (int n,Date & dt)
{
return dt+n;
}
int main()
{
Date olddate(1,1,2005);
Date newdate;
newdate=olddate+100;
lay();
return 0;
}
上面的例子中非類成員過載運算子函式呼叫了類中的過載+運算子來實現加法運算。如果類當中沒有提供這樣的函式,那麼非類成員的過載運算子函式將被迫訪問類的私有資料來實現加法運算。這樣的話,需要把這個函式宣告為類的友元,如下:
class Date
{
friend Date operator + (int n,Date &);
};
上例中過載運算子函式聲明瞭全部兩個引數,這是因為它不是類的成員,因此它不能作為類的成員函式被呼叫,就缺少了一個隱含的引數。
第一個過載加法運算子函式也可以用類的友元函式來實現。作為一種約定,這通常把所有為類過載的運算子都設定為該類的友元。
例子中只給出了過載加法的程式碼,我們同樣可以來過載減法,乘除法等等。
三、過載關係運算符
如果想要對兩個日期進行比較,比如出現下面這樣的程式碼:
if(olddate 可以向上面用類似的方法過載關係運算符
#include iostream.h
class Date
{
int mo,da,yr;
public:
Date(int m=0,int d=0,int y=0)
{ mo=m; da=d; yr=y;}
void display() const
{ cout < int operator == (Date& dt) const;
int operator < (Date& dt) const;
};
int Date::operator== (Date & dt) const
{
return (this- >mo== && this->da== && this->yr==);
}
int Date::operator < (Date& dt) const
{
if(this- >yr == )
{
if(this- >mo == ) return this->da < ;
return this- >mo < ;
}
return this- >yr < ;
}
int main()
{
Date date1(2,14,2005);
Date date2(6,9,2005);
Date date3(2,14,2005);
if(date1 {
lay();
cout < lay();
}
cout < if(date1==date3)
{
lay();
cout < lay();
}
return 0;
}
可以類似的過載其他關係運算符,如!=
int operator != (Date & dt) { return !(*this==dt);}
四、其他賦值運算子
#include iostream.h
class Date
{
int mo,da,yr;
static int dys[];
public:
Date(int m=0,int d=0,int y=0)
{ mo=m; da=d; yr=y;}
void display() const
{ cout < Date operator + (int) const;
Date operator +=(int)
{ *this=*this+n; return *this;}
};
int Date::dys[]={31,28,31,30,31,30,31,31,30,31,30,31};
Date Date::operator+(int) const
{
Date dt=*this;
n+=;
while(n >=dys[-1])
{
n-=dys[-1];
if(++==13)
{
=1;
dt,yr++;
}
}
=n;
return dt;
}
int main()
{
Date olddate(1,1,2005);
olddate+=100;
lay();
return 0;
}