程序清单 11.10 列出了修改后的类定义,其中包括 operator*()和 operator<<()这两个友元函数。它将第一个友元函数作为内联函数,因为其代码很短。(当定义同时也是原型时,就像这个例子中那样,要使用 fiend 前缀。)
警告:只有在类声明中的原型中才能使用 fiend 关键字。除非函数定义也是原型,否则不能在函数定义中使用该关键字。
#ifndef MYTIME2_H_
#define MYTIME3_H_
#include<iostream>
class Time
{
private:
int hours;
int minutes;
public:
Time();
Time(int h, int m = 0);
void AddMin(int m);
void AddHr(int h);
void Reset(int h = 0, int m = 0);
Time operator+(const Time& t)const;
Time operator-(const Time& t)const;
Time operator*(double n)const;
friend Time operator*(double m, const Time& t)
{
return t * m;
} //lnline definition
friend std::ostream& operator <<(std::ostream& os, const Time& t); //重定义<<
};
#endif // !MYTIME1_H_
#endif // 0
程序清单 11.11列出了修改后的定义。方法使用了 Time::限定符,而友元函数不使用该限定符。另外,由于在 mytime3.h中包含了iostream 并提供了using声明std::ostream,因此在 mytime3.cpp中包含 mytime3.h后,便提供了在实现文件中使用ostream的支持。
//mytime2.cpp -- implementing Time methods
#if 1
#include<iostream>
#include"mytime3.h"
Time::Time()
{
hours = minutes = 0;
}
Time::Time(int h, int m)
{
hours = h;
minutes = m;
}
void Time::AddMin(int m)
{
minutes += m;
hours += minutes / 60;
minutes %= 60;
}
void Time::AddHr(int h)
{
hours += h;
}
void Time::Reset(int h, int m)
{
hours = h;
minutes = m;
}
Time Time::operator+(const Time& t)const
{
Time sum;
sum.minutes = minutes + t.minutes;
sum.hours = hours + t.hours + sum.minutes / 60;
sum.minutes %= 60;
return sum;
}
Time Time::operator-(const Time& t)const
{
Time diff;
int tot1, tot2;
tot1 = t.minutes + 60 * t.hours;
tot2 = minutes + 60 * hours;
diff.minutes = (tot2 - tot1) % 60;
diff.hours = (tot2 - tot1) / 60;
return diff;
}
Time Time::operator*(double mult)const
{
Time result;
long totalminutes = hours * mult * 60 + minutes * mult;
result.hours = totalminutes / 60;
result.minutes = totalminutes % 60;
return result;
}
std::ostream& operator<<(std::ostream& os, const Time& t)
{
os << t.hours << " hours, " << t.minutes << " minutes";
return os;
}
#endif // 0
程序清单 11.12是一个示例程序。从技术上说,在usetime3.cpp中不必包含头文件iostream,因为在mytime3.h中已经包含了该文件。然而,作为 Time 类的用户,您并不知道在类代码文件中已经包含了哪些文件,因此您应负责将您编写的代码所需的头文件包含进来。
#pragma region 11.12 usetime3.cpp
////程序清单
//xxx.cpp -- xxx
#if 1
#include <iostream>
#include"mytime3.h"
int main()
{
using std::cout;
using std::endl;
Time aida(3, 35);
Time tosca(2, 48);
Time temp;
cout << "Aida and Tosca:\n";
cout << aida << "; " << tosca << endl;
temp = aida + tosca;
cout << "Aida+Tosca:" << temp << endl;
temp = aida * 1.17;
cout << "Aida*1.17:" << temp << endl;
temp = 10.0 * tosca;
cout << "10.0*Tosca: " << temp << endl;
return 0;
}
#endif
#pragma endregion

咋一看打印结果不对啊,这是因为<<做了重载操作
给大家加一个作业:在上面的代码之上加上这样一句:
cout << endl;
Time a;
cout << a;
大家说打印内容?
891

被折叠的 条评论
为什么被折叠?



