1. 程式人生 > >C++實踐參考——Time類中的運算子過載

C++實踐參考——Time類中的運算子過載

【專案-Time類中的運算子過載】
  實現Time類中的運算子過載。

class CTime
{
private:
    unsigned short int hour;    // 時
    unsigned short int minute;  // 分
    unsigned short int second;  // 秒
public:
    CTime(int h=0,int m=0,int s=0);
    void setTime(int h,int m,int s);
    void display();
    //二目的比較運算子過載
    bool operator > (CTime &t);
    bool
operator < (CTime &t); bool operator >= (CTime &t); bool operator <= (CTime &t); bool operator == (CTime &t); bool operator != (CTime &t); //二目的加減運算子的過載 //返回t規定的時、分、秒後的時間 //例t1(8,20,25),t2(11,20,50),t1+t2為19:41:15 CTime operator+(CTime &t); CTime operator
-(CTime &t);//對照+理解 CTime operator+(int s);//返回s秒後的時間 CTime operator-(int s);//返回s秒前的時間 //二目賦值運算子的過載 CTime &operator+=(CTime &c); CTime &operator-=(CTime &c); CTime &operator+=(int s);//返回s秒後的時間 CTime &operator-=(int s);//返回s秒前的時間 //一目運算子的過載 CTime operator
++(int);//後置++,下一秒 CTime &operator++();//前置++,下一秒 CTime operator--( int);//後置--,前一秒 CTime &operator--();//前置--,前一秒 };

提示1:並不是所有比較運算過載函式都很複雜

//比較運算返回的是比較結果,是bool型的true或false
//可以直接使用已經過載了的運算實現新運算,例如果已經實現了 > ,則實現 <= 就可以很方便了……
bool CTime::operator <= (CTime &t) // 判斷時間t1<=t2
{
    if (*this > t) return false;
    return true;
}

甚至可以如下面的程式碼般簡練:

bool CTime::operator <= (CTime &t){return !(*this > t)}

提示2:並不是所有複合賦值運算過載函式都需要很複雜

//可以直接使用已經過載了的加減運算實現
//這種賦值, 例如 t1+=20,直接改變當前物件的值,所以在運算完成後,將*this作為返回值
CTime &CTime::operator+=(CTime &c)
{
    *this=*this+c;
    return *this;
}

提示3:請自行編制用於測試的main()函式,有些結果不必依賴display()函式,提倡用單步執行檢視結果

[參考解答]

#include <iostream>
using namespace std;
class CTime
{
private:
    unsigned short int hour;    // 時
    unsigned short int minute;  // 分
    unsigned short int second;  // 秒
public:
    CTime(int h=0,int m=0,int s=0);
    void setTime(int h,int m,int s);

    //輸入輸出運算的過載
    friend istream &operator>>(istream &in,CTime &t);
    friend ostream &operator<<(ostream &out,CTime t);
    //比較運算子(二目)的過載
    bool operator > (CTime &t);
    bool operator < (CTime &t);
    bool operator >= (CTime &t);
    bool operator <= (CTime &t);
    bool operator == (CTime &t);
    bool operator != (CTime &t);
    //二目運算子的過載
    CTime operator+(CTime &c);//返回c所規定的時、分、秒後的時間,例t1(8,20,25),t2(11,20,50),t1+t2為:41:15
    CTime operator-(CTime &c);//對照+理解
    CTime operator+(int s);//返回s秒後的時間
    CTime operator-(int s);//返回s秒前的時間
    //一目運算子的過載
    CTime operator++(int);//後置++,下一秒
    CTime &operator++();//前置++,下一秒
    CTime operator--(int);//後置--,前一秒
    CTime &operator--();//前置--,前一秒
    //賦值運算子的過載
    CTime &operator+=(CTime &c);
    CTime &operator-=(CTime &c);
    CTime &operator+=(int s);//返回s秒後的時間
    CTime &operator-=(int s);//返回s秒前的時間
};

//建構函式
CTime::CTime(int h,int m,int s)
{
    hour=h;
    minute=m;
    second=s;
}
// 設定時間
void CTime::setTime(int h,int m,int s)
{
    hour=h;
    minute=m;
    second=s;
}

// 過載輸入運算子>>
istream &operator>>(istream &in,CTime &t)
{
    char ch1,ch2;
    while(1)
    {
        cout<<"請輸入時間(hh:mm:ss) ";
        cin>>t.hour>>ch1>>t.minute>>ch2>>t.second;
        if (ch1==':' && ch2==':')
            if (t.hour>-1 && t.hour<24 && t.minute>-1 && t.minute<60 && t.second>-1 && t.second<60) break;
        cerr<<"時間格式不正確! 請重新輸入\n";
    }
    return cin;
}

// 過載輸出運算子<<
ostream &operator<<(ostream &out,CTime t)
{
    out<<t.hour<<':'<<t.minute<<':'<<t.second;
    return out;
}


//比較運算子的過載
bool CTime::operator > (CTime &t) // 判斷時間t1>t2
{
    if (hour>t.hour) return true;
    if (hour<t.hour) return false;
    if (minute>t.minute) return true;
    if (minute<t.minute) return false;
    if (second>t.second) return true;
    return false;
}

bool CTime::operator < (CTime &t)// 判斷時間t1<t2
{
    if (hour<t.hour) return true;
    if (hour>t.hour) return false;
    if (minute<t.minute) return true;
    if (minute>t.minute) return false;
    if (second<t.second) return true;
    return false;
}

bool CTime::operator == (CTime &t)// 判斷時間t1==t2
{
    if (*this<t || *this>t) return false;
    return true;
}

bool CTime::operator != (CTime &t) // 判斷時間t1!=t2
{
    if (*this==t) return false;
    return true;
}

bool CTime::operator >= (CTime &t)// 判斷時間t1>=t2
{
    if (*this<t) return false;
    return true;
}

bool CTime::operator <= (CTime &t) // 判斷時間t1<=t2
{
    if (*this>t) return false;
    return true;
}

//二目運算子的過載
// 計算時間之和, 返回c所規定的時、分、秒後的時間,例t1(8,20,25),t2(11,20,50),t1+t2為:41:15
CTime CTime::operator + (CTime &t)
{

    int h,m,s;
    s=second+t.second;
    m=minute+t.minute;
    h=hour+t.hour;
    if (s>59)
    {
        s-=60;
        m++;
    }
    if (m>59)
    {
        m-=60;
        h++;
    }
    while (h>23) h-=24;
    CTime t0(h,m,s);
    return t0;
}

//返回s秒後的時間
CTime CTime::operator+(int s)
{
    int ss=s%60;
    int mm=(s/60)%60;
    int hh=s/3600;
    CTime t0(hh,mm,ss);
    return *this+t0;
}

// 計算時間之差
CTime CTime::operator - (CTime &t)
{
    int h,m,s;
    s=second-t.second;
    m=minute-t.minute;
    h=hour-t.hour;
    if (s<0)
    {
        s+=60;
        m--;
    }
    if (m<0)
    {
        m+=60;
        h--;
    }
    while (h<0) h+=24;
    CTime t0(h,m,s);
    return t0;
}

//返回s秒前的時間
CTime CTime::operator-(int s)
{
    int ss=s%60;
    int mm=(s/60)%60;
    int hh=s/3600;
    CTime t0(hh,mm,ss);
    return *this-t0;
}

//一目運算子的過載
CTime CTime::operator++(int)//後置++,下一秒
{
    CTime t=*this;
    *this=*this+1;
    return t;
}

CTime &CTime::operator++()//前置++,下一秒
{
    *this=*this+1;
    return *this;
}

CTime CTime::operator--(int)//後置--,前一秒
{
    CTime t=*this;
    *this=*this-1;
    return t;
}

CTime &CTime::operator--()//前置--,前一秒
{
    *this=*this-1;
    return *this;
}

//賦值運算子的過載
CTime &CTime::operator+=(CTime &c)
{
    *this=*this+c;
    return *this;
}
CTime &CTime::operator-=(CTime &c)
{
    *this=*this-c;
    return *this;
}
CTime &CTime::operator+=(int s)//返回s秒後的時間
{
    *this=*this+s;
    return *this;
}
CTime &CTime::operator-=(int s)//返回s秒前的時間
{
    *this=*this-s;
    return *this;
}

int main()
{
    CTime t1,t2,t;

    cout<<"t1為:";
    cin>>t1;
    cout<<"t2為:";
    cin>>t2;
    cout<<"下面比較兩個時間大小:\n";
    if (t1>t2) cout<<"t1>t2"<<endl;
    if (t1<t2) cout<<"t1<t2"<<endl;
    if (t1==t2) cout<<"t1=t2"<<endl;
    if (t1!=t2) cout<<"t1≠t2"<<endl;
    if (t1>=t2) cout<<"t1≥t2"<<endl;
    if (t1<=t2) cout<<"t1≤t2"<<endl;
    cout<<endl;
    cout<<"t1= "<<t1<<endl;
    cout<<"t2= "<<t2<<endl;

    cout<<"t=t1++"<<endl;
    t=t1++;
    cout<<"t= "<<t<<"    t1= "<<t1<<endl;

    cout<<"t=++t1"<<endl;
    t=++t1;
    cout<<"t= "<<t<<"    t1= "<<t1<<endl;

    cout<<"t1+t2= "<<t1+t2<<endl;
    cout<<"t1-t2= "<<t1-t2<<endl;
    cout<<"t1+2000= "<<t1+2000<<endl;
    cout<<"t1-5000= "<<t1-5000<<endl;
    return 0;
}