博客
关于我
c++入门之运算符重载
阅读量:454 次
发布时间:2019-03-06

本文共 2155 字,大约阅读时间需要 7 分钟。

C++函数重载的应用:运算符重载的意义与实现

在C++编程中,运算符重载是一个非常重要且有趣的概念。它允许我们为同一个符号赋予不同的含义,从而在不同的上下文中发挥不同的功能。这种机制不仅适用于基本类型的运算符重载,如指针的加法运算,也适用于用户定义的类对象。通过运算符重载,我们可以为类添加新的行为,使得类之间的操作更加灵活和便捷。

运算符重载的意义

运算符重载的本质是允许我们通过重定义运算符的行为,将其与用户自定义的类对象关联起来。例如,在编程时,当我们使用+运算符进行两个对象的加法操作时,实际上调用的是类中定义的operator+函数。这种机制允许我们以更高层次的方式处理对象之间的关系,而不仅仅是简单地执行内置的加法操作。

类运算符重载的实现

以一个具体的例子来说明,我们可以定义一个名为Time的类,表示时间。该类包含小时和分钟的成员变量,以及一系列操作方法,包括AddMin、AddHr、Reset等。为了支持加法运算,我们需要重定义operator+运算符。

类声明

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;
void Show() const;
};

类实现

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;
}
void Time::Show() const {
using std::cout;
using std::endl;
cout << hours << " hours," << minutes << " minutes" << endl;
}

类调用示例

#include 
#include "mytime0.h"
int main() {
using std::cout;
using std::endl;
Time planning;
Time coding(2, 40);
Time fixing(5, 55);
Time total;
cout << "planning time =";
planning.Show();
cout << endl;
cout << "coding time =";
coding.Show();
cout << endl;
cout << "fixing time =";
fixing.Show();
cout << endl;
total = coding + fixing;
cout << "total time =";
total.Show();
cout << endl;
system("pause");
return 0;
}

运算符重载的背后

当我们使用coding + fixing进行运算时,实际上是在调用coding.operator+(fixing)方法。这个方法返回了一个新的Time对象,其成员变量表示了两个Time对象的和。从技术实现来看,运算符重载并没有将两个对象"相加"字面意义上的数值,而是通过调用特定的方法来实现这个操作。

总结

运算符重载为C++提供了一种强大的元编程能力。通过重定义运算符的行为,我们可以将其与用户定义的类紧密结合,从而实现更复杂的操作。这种机制不仅提升了代码的可读性和可维护性,也为我们提供了一种灵活的方式来处理不同类型的对象之间的关系。在实际编程中,运算符重载是设计高级数据结构和算法的重要工具。

转载地址:http://gbpfz.baihongyu.com/

你可能感兴趣的文章
Objective-C实现Edmonds-Karp算法(附完整源码)
查看>>
Objective-C实现EEMD算法(附完整源码)
查看>>
Objective-C实现elgamal 密钥生成器算法(附完整源码)
查看>>
Objective-C实现EM算法(附完整源码)
查看>>
Objective-C实现EM算法(附完整源码)
查看>>
Objective-C实现entropy熵算法(附完整源码)
查看>>
Objective-C实现euclidean distance欧式距离算法(附完整源码)
查看>>
Objective-C实现Euclidean GCD欧几里得最大公约数算法(附完整源码)
查看>>
Objective-C实现euclideanDistance欧氏距离算法(附完整源码)
查看>>
Objective-C实现euler method欧拉法算法(附完整源码)
查看>>
Objective-C实现euler modified变形欧拉法算法(附完整源码)
查看>>
Objective-C实现eulerianPath欧拉路径算法(附完整源码)
查看>>
Objective-C实现Eulers TotientFunction欧拉函数算法(附完整源码)
查看>>
Objective-C实现eulers totient欧拉方程算法(附完整源码)
查看>>
Objective-C实现EulersTotient欧拉方程算法(附完整源码)
查看>>
Objective-C实现eval函数功能(附完整源码)
查看>>
Objective-C实现even_tree偶数树算法(附完整源码)
查看>>
Objective-C实现Exceeding words超词(差距是ascii码的距离) 算法(附完整源码)
查看>>
Objective-C实现exchange sort交换排序算法(附完整源码)
查看>>
Objective-C实现ExponentialSearch指数搜索算法(附完整源码)
查看>>