c++运算符重载的方法有哪些
c++运算符重载的方法有哪些?
有两种方法可以使运算符重载:
1、使重载运算符成为该类的成员函数。这允许运算符函数访问类的私有成员。它也 允许函数使用隐式的this指针形参来访问调用对象。
2、使重载的成员函数成为独立分开的函数。当以这种方式重载时,运算符函数必须 声明为类的友元才能访问类的私有成员。
某些运算符(如流输入运算符 >> 和流输出运算符 <<)必须作为独立函数重载。其他运算符既可以作为成员函数也可以作为独立函数重载。
假设已经编写了以下独立重载函数代码:
Length a(4, 2), b(1, 8), c (0); c = a + b;
该代码将被编译器解释为以下形式:
Length a(4, 2), b(1, 8), c(0); c = operator+(a, b);
编译器允许程序员使用友好的中间插入符号。但是,它将运算符视为一个普通函数,其名称是 operator+,这有一种不是很明显的意味。例如,来看以下语句:
c = 2 + a;
相当于以下语句:
c = operator+(2, b);
这两个语句都能正确编译和执行,因为 Length 类的转换构造函数能够在整数形参 2 之外创建一个 Length 对象。
算术和关系运算符的重载可以像成员函数的重载一样轻松。加法运算符的重载方法如下。首先,修改类内声明以使该运算符变成一个成员函数:
class Length { private: int len_inches; public: //修改operator+的声明 Length operator+(Length b); //类的其余部分,省略 };
请注意,该运算符现在被声明为釆用 Length 类型的单个运算符,这是因为作为一个成员函数,该运算符被自动通过隐式形参 this 传递一个 Length 对象。例如,如果编写以下语句:
Length a(4, 2), b(1, 8), c(0); c = a + b;
则编译器会将此语句视为以下形式的内容:
Length a(4, 2), b(1, 8), c (0); c = a.operator+ (b);
在编写 a + b 时,重载的 + 运算符的左操作数变成了调用成员函数的对象,右操作数变成了显式形参。伴随着这些变化,运算符的主体被写成如下形式的语句:
Length Length::operator+(Length b) { return Length(this->len_inches + b.len_inches); }
综上所述,加法运算符(以及其他算术运算符和关系运算符)既可以作为成员函数,也可以作为独立函数重载。
一般来说,更好的做法是将二元运算符重载为釆用相同类型形参的独立函数。这是因为,与独立运算符的重载不同,成员函数的重载通过使左侧形参变成隐式的,造成了两个形参之间的人为区别,这将允许转换构造函数应用右侧形参,但不应用左侧形参,从而产生了更改形参顺序的情况,导致正确的程序如果换个方式却出现了编译器错误。示例如下:
Length a(4, 2), c(0); c = a + 2; //编译,当于 c = a.operator+ (2) c = 2 + a; //不能编译:相当于 c = 2 .operator+ (a);
推荐教程: 《c++》
以上是c++运算符重载的方法有哪些的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

策略模式在C++中的实现步骤如下:定义策略接口,声明需要执行的方法。创建具体策略类,分别实现该接口并提供不同的算法。使用上下文类持有具体策略类的引用,并通过它执行操作。

Golang和C++分别是垃圾回收和手动内存管理编程语言,语法和类型系统各异。Golang通过Goroutine实现并发编程,C++通过线程实现。Golang内存管理简单,C++性能更强。实战案例中,Golang代码更简洁,C++性能优势明显。

嵌套异常处理在C++中通过嵌套的try-catch块实现,允许在异常处理程序中引发新异常。嵌套的try-catch步骤如下:1.外部try-catch块处理所有异常,包括内部异常处理程序抛出的异常。2.内部try-catch块处理特定类型的异常,如果发生超出范围的异常,则将控制权交给外部异常处理程序。

要遍历STL容器,可以使用容器的begin()和end()函数获取迭代器范围:向量:使用for循环遍历迭代器范围。链表:使用next()成员函数遍历链表元素。映射:获取键值对迭代器,使用for循环遍历。

C++模板继承允许模板派生类重用基类模板的代码和功能,适用于创建具有相同核心逻辑但不同特定行为的类。模板继承语法为:templateclassDerived:publicBase{}。实例:templateclassBase{};templateclassDerived:publicBase{};。实战案例:创建了派生类Derived,继承了基类Base的计数功能,并增加了printCount方法来打印当前计数。

C++模板在实际开发中广泛应用,包括容器类模板、算法模板、泛型函数模板和元编程模板。例如,泛型排序算法可对不同类型数据的数组进行排序。

在多线程C++中,异常处理通过std::promise和std::future机制实现:在抛出异常的线程中使用promise对象记录异常。在接收异常的线程中使用future对象检查异常。实战案例展示了如何使用promise和future在不同线程中捕获和处理异常。

如何访问C++STL容器中的元素?有以下几种方法:遍历容器:使用迭代器基于范围的for循环访问特定元素:使用索引(下标运算符[])使用键(std::map或std::unordered_map)
