C++ 允许在同一作用域中的某个函数和运算符指定多个定义,分别称为函数重载和运算符重载。重载声明是指一个与之前已经在该作用域内声明过的函数或方法具有相同名称的声明,但是它们的参数列表和定义(实现)不相同。
当您调用一个重载函数或重载运算符时,编译器通过把您所使用的参数类型与定义中的参数类型进行比较,决定选用最合适的定义。选择最合适的重载函数或重载运算符的过程,称为重载决策。
在同一个作用域内,可以声明几个功能类似的同名函数,但是这些同名函数的形式参数(指参数的个数、类型或者顺序)必须不同。您不能仅通过返回类型的不同来重载函数。
下面的示例中,同名函数 print() 被用于输出不同的数据类型:
- #include
-
-
- class printdata {
- public:
- void print(int i) {
- std::cout << "整数为:" << i << std::endl;
- }
-
- void print(double f) {
- std::cout << "浮点数:" << f << std::endl;
- }
- void print(char str[]) {
- std::cout << "字符串为:" << str << std::endl;
- }
- };
-
- int main() {
- printdata pd;
- // 输出整数
- pd.print(5);
- // 输出浮点数
- pd.print(500.63);
- // 输出字符串
- char c[] = "hello c++";
- pd.print(c);
-
- return 0;
- }
输出结果:
您可以重定义或重载大部分 C++ 内置的运算符。这样,您就能使用自定义类型的运算符。重载的运算符是带有特殊名称的函数,函数名是由关键字 operator 和其后要重载的运算符符号构成的。与其他函数一样,重载运算符有一个返回类型和一个参数列表。
Box operator+(const Box&);
声明加法运算符用于把两个 Box 对象相加,返回最终的 Box 对象。大多数的重载运算符可被定义为普通的非成员函数或者被定义为类成员函数。如果我们定义上面的函数为类的非成员函数,那么我们需要为每次操作传递两个参数,如下所示:
Box operator+(const Box&, const Box&);
下面的示例使用成员函数演示了运算符重载的概念。在这里,对象作为参数进行传递,对象的属性使用 this 运算符进行访问,如下所示:
- #include
- class Box {
- private:
- double length; // 长度
- double breadth; // 宽度
- double height; // 高度
-
- 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;
- }
-
- };
-
- // 程序的主函数
-
- 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();
- std::cout << "Box1的体积:" << volume << std::endl;
- // Box2的体积
- volume = Box2.getvolume();
- std::cout << "Box2的体积:" << volume << std::endl;
- // 把两个对象相加,得到Box3
- Box3 = Box1 + Box2;
-
- // Box3的体积
- volume = Box3.getvolume();
- std::cout << "Box3的体积:" << volume << std::endl;
- return 0;
-
- }
输出结果:
下面是可重载的运算符列表:
双目算术运算符 | + (加),-(减),*(乘),/(除),% (取模) |
关系运算符 | ==(等于),!= (不等于),< (小于),> (大于),<=(小于等于),>=(大于等于) |
逻辑运算符 | ||(逻辑或),&&(逻辑与),!(逻辑非) |
单目运算符 | + (正),-(负),*(指针),&(取地址) |
自增自减运算符 | ++(自增),--(自减) |
位运算符 | | (按位或),& (按位与),~(按位取反),^(按位异或),,<< (左移),>>(右移) |
赋值运算符 | =, +=, -=, *=, /= , % = , &=, |=, ^=, <<=, >>= |
空间申请与释放 | new, delete, new[ ] , delete[] |
其他运算符 | ()(函数调用),->(成员访问),,(逗号),[](下标) |
下面是不可重载的运算符列表:
.:成员访问运算符
.*, ->*:成员指针访问运算符
:::域运算符
sizeof:长度运算符
?::条件运算符
#: 预处理符号
下面提供了各种运算符重载的示例,帮助您更好地理解重载的概念。
序号 | 运算符和示例 |
---|---|
1 | 一元运算符重载 |
2 | 二元运算符重载 |
3 | 关系运算符重载 |
4 | 输入/输出运算符重载 |
5 | ++ 和 -- 运算符重载 |
6 | 赋值运算符重载 |
7 | 函数调用运算符 () 重载 |
8 | 下标运算符 [] 重载 |
9 | 类成员访问运算符 -> 重载 |