重载运算符

Posted 背着代码的蜗牛

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了重载运算符相关的知识,希望对你有一定的参考价值。


重载运算符

为什么要重载运算符:
C++中预定义的运算符的操作对象只能是基本数据类型。但实际上,对于许多用户自定义类型(例如结构体),也需要类似的运算操作。这时就必须在C++中重新定义这些运算符,赋予已有运算符新的功能,使它能够用于特定类型执行特定的操作。运算符重载的实质是函数重载,它提供了C++的可扩展性,也是C++最吸引人的特性之一。
什么是重载运算符:
简单来说:运算符重载,就是对已有的运算符重新进行定义,赋予其另一种功能,以适应不同的数据类型。
如何实现:
运算符重载是通过创建运算符函数实现的,运算符函数定义了重载的运算符将要进行的操作。运算符函数的定义与其他函数的定义类似,惟一的区别是运算符函数的函数名是由关键字operator和其后要重载的运算符符号构成的。
运算符重载为类的成员函数的一般格式为:
<函数类型> operator <运算符>(<参数表>)const

<函数体>

以重载“<”运算符为例:

#include<iostream>
#include<algorithm>
using namespace std;
const int maxn=100;
struct node//定义结构体

int a;
int b;
bool operator < (node tmp)const//重载运算符函数

if(a==tmp.a)
return b<tmp.b;//注意运算符的开口方向,此处为按照b的升序排序(从小到大)
return a>tmp.a;//按照a的降序排序(从大到小)

e[maxn];
int n;
int main()

cin>>n;
for(int i=1;i<=n;i++)
cin>>e[i].a>>e[i].b;
sort(e+1,e+n+1);//排序,因为已经重载了运算符,所以不用再写比较函数
for(int i=1;i<=n;i++)
cout<<e[i].a<<" ";
return 0;

不使用重载运算符:

#include<iostream>
#include<algorithm>
using namespace std;
const int maxn=100;
struct node

int a;
int b;
e[maxn];
int n;
bool cmp(node x,node y)//排序函数

if(x.a==y.a)
return x.b<y.b;
return x.a>y.a;

int main()

cin>>n;
for(int i=1;i<=n;i++)
cin>>e[i].a>>e[i].b;
sort(e+1,e+n+1,cmp);//需要写一个排序函数cmp
for(int i=1;i<=n;i++)
cout<<e[i].a<<" ";
return 0;


以上是关于重载运算符的主要内容,如果未能解决你的问题,请参考以下文章

C++运算符重载

运算符重载

运算符重载

运算符重载1

第十章 运算符重载

重载运算符