目录
函数重载
运算符重载
当调用一个重载函数或重载运算符时,编译器通过把所使用的参数类型与定义中的参数类型进行比较,决定选用最合适的定义。选择最合适的重载函数或重载运算符的过程,称为重载决策。
函数重载 在同一个作用域内,可以声明几个功能类似的同名函数,但是这些同名函数的形式参数(指参数的个数、类型或者顺序)必须不同,不能仅通过返回类型的不同来重载函数。
实例:同名函数 print() 被用于输出不同的数据类型
#include
using namespace std;
class printData
{
public:
void print(int i) {
cout << "整数为: " << i << endl;
}
void print(doublef) {
cout << "浮点数为: " << f << endl;
}
void print(char c[]) {
cout << "字符串为: " << c << endl;
}
};
int main(void)
{
printData pd;
// 输出整数
pd.print(5);
// 输出浮点数
pd.print(500.263);
// 输出字符串
char c[] = "Hello C++";
pd.print(c);
return 0;
}
输出:
整数为: 5运算符重载 重载的运算符是带有特殊名称的函数,函数名是由关键字 operator 和其后要重载的运算符符号构成的。与其他函数一样,重载运算符有一个返回类型和一个参数列表
浮点数为: 500.263
字符串为: Hello C++
【C++|C++(重载运算符和重载函数)】实例: 声明加法运算符用于把两个 Box 对象相加,返回最终的 Box 对象。在这里,对象作为参数进行传递,对象的属性使用 this 运算符进行访问。
#include
using namespace std;
class Box
{
public:
double getVolume(void)
{
return length * breadth * height;
}
void setLength( double len )
{
length = len;
}
void setBreadth( double bre )
{
breadth = bre;
}
void setHeight( double hei )
{
height = hei;
}
// 重载 + 运算符,用于把两个 Box 对象相加
Box operator+(const Box& b)
{
Box box;
box.length = this->length + b.length;
box.breadth = this->breadth + b.breadth;
box.height = this->height + b.height;
return box;
}
private:
double length;
// 长度
double breadth;
// 宽度
double height;
// 高度
};
// 程序的主函数
int main( )
{
Box Box1;
// 声明 Box1,类型为 Box
Box Box2;
// 声明 Box2,类型为 Box
Box Box3;
// 声明 Box3,类型为 Box
double volume = 0.0;
// 把体积存储在该变量中
// Box1 详述
Box1.setLength(6.0);
Box1.setBreadth(7.0);
Box1.setHeight(5.0);
// Box2 详述
Box2.setLength(12.0);
Box2.setBreadth(13.0);
Box2.setHeight(10.0);
// Box1 的体积
volume = Box1.getVolume();
cout << "Volume of Box1 : " << volume <
输出:
Volume of Box1 : 210参考资料:
Volume of Box2 : 1560
Volume of Box3 : 5400
https://www.runoob.com/cplusplus/cpp-overloading.html
推荐阅读
- 个人日记|K8s中Pod生命周期和重启策略
- 数据结构和算法|LeetCode 的正确使用方式
- 设计模式|设计模式_创建型模式——工厂方法
- 学习分享|【C语言函数基础】
- #|7.分布式事务管理
- C++|C++浇水装置问题
- 数据结构|C++技巧(用class类实现链表)
- C++|从零开始学C++之基本知识
- 步履拾级杂记|VS2019的各种使用问题及解决方法
- leetcode题解|leetcode#106. 从中序与后序遍历序列构造二叉树