网站首页 > 技术文章 正文
引言
上一篇文章中,我们简单聊了通过定义魔术方法,自定义类型也可以像内置的整型、浮点型等一样,也能进行比较运算。今天,我们接着聊运算符重载的话题,通过魔术方法实现自定义类型四则运算的功能。
需要说明的是,虽然,我们一直在用“运算符重载”这个名词,实际上是C++等编程语言中的技术,Java中虽然支持函数重载,但是也不支持运算符重载,所以很难实现类似于内置类型的操作。Python虽然没有运算符重载的功能,但是,魔术方法实现了运算符重载同样的功能。
本文的主要内容有:
1、算术运算符的分类
2、算术运算相关的魔术方法
3、自定义类型实现算术运算操作
算术运算符的分类
算术运算符常见的分类方法有如下几种:
1、按照参与运算的对象个数,可以分为一元运算符和二元运算符。
2、按照真正调用方法的对象来看,二元运算符中,又可以分为正向运算(左侧对象真正调用方法)和反向运算(右侧对象真正调用方法)。
3、按照运算符的结果来看,又可以分为普通运算符(不可变操作对象本身)和增量运算符(改变操作对象本身)。
这不同的算术运算符,在Python中都有对应的魔术方法,我们在实际业务中,可以根据操作的需要,自由选择实现其中某个或者某几个的组合。
算术运算相关的魔术方法
下面简单列举一下Python中关于算术运算相关的魔术方法。
首先是正向的运算符所对应的魔术方法:
1、__add__(self, other):正向加法运算。
2、__sub__(self, other):正向减法运算。
3、__mul__(self, other):正向乘法运算。
4、__truediv__(self, other):正向除法运算。
5、__floordiv__(self, other):正向地板除法运算。
6、__mod__(self, other):正向取模运算。
7、__pow__(self, other):正向幂运算。
其次是反向运算符所对应的魔术方法:
1、__radd__(self, other):反向加法运算。
2、__rsub__(self, other):反向减法运算。
3、__rmul__(self, other):反向乘法运算。
4、__rtruediv__(self, other):反向除法运算。
5、__rfloordiv__(self, other):反向地板除法运算。
6、__rmod__(self, other):反向取模运算。
7、__rpow__(self, other):反向幂运算。
可以看到,每个反向运算符对应的魔术方法,都是正向方法前面多了一个前缀r,表示“reverse”。
然后是增量运算符(原地运算)所对应的魔术方法:
1、__iadd__(self, other):增量加法运算。
2、__isub__(self, other):增量减法运算。
3、__imul__(self, other):增量乘法运算。
4、__itruediv__(self, other):增量除法运算。
5、__ifloordiv__(self, other):增量地板除法运算。
6、__imod__(self, other):增量取模运算。
7、__ipow__(self, other):增量幂运算。
可以看到,每个增量运算符的魔术方法,前面的前缀都是i,表示inplace的意思。
最后再来看一下,一元操作符所对应的魔术方法:
1、__neg__(self):只有一个参数,用于实现-self。
2、__pos__(self):只有一个参数,用于实现+self。
3、__invert__(self):只有一个参数,用于实现~self。
自定义类型实现算术运算操作
接下来,简单通过代码演示一下几个常见的算术运算相关的魔术方法的使用。
直接看代码:
class Vector:
def __init__(self, x, y):
self.x = x
self.y = y
# 正向加
def __add__(self, other):
if isinstance(other, self.__class__):
return self.__class__(self.x + other.x, self.y + other.y)
if isinstance(other, tuple) and len(other) == 2:
return self.__class__(self.x + other[0], self.y + other[1])
raise NotImplemented
# 反向减
def __rsub__(self, other):
if isinstance(other, self.__class__):
return self.__class__(other.x - self.x, other.y - self.y)
if isinstance(other, tuple) and len(other) == 2:
return self.__class__(other[0] - self.x, other[1] - self.y)
raise NotImplemented
# 原地加
def __iadd__(self, other):
if isinstance(other, self.__class__):
self.x += other.x
self.y += other.y
return self
raise NotImplemented
# 一元运算
def __neg__(self):
return self.__class__(-self.x, -self.y)
def __str__(self):
return f'Vector({self.x}, {self.y})'
if __name__ == '__main__':
v1 = Vector(10, 20)
print(v1)
v2 = Vector(100, 200)
print(v2)
v3 = v1 + v2
print(v3)
v4 = v1 + (1, 2)
print(v4)
v5 = -v2
print(v5)
v5 += v1
print(v5)
运行结果:

总结
本文简单介绍了算术运算符的分类,比如:一元运算符、二元运算符、增量运算符、反向运算符等。然后,又列举了常见的算术运算符对应的魔术方法。最后通过一个向量类的实例,演示了算术运算符相关魔术方法的使用。
感谢您的拨冗阅读,希望对您有所帮助!

猜你喜欢
- 2024-12-15 一文了解 “*” 星号在 Python 中的多种用法
- 2024-12-15 什么是序列,Python序列详解(包括序列类型和常用操作)
- 2024-12-15 python中pyd文件的使用 py文件edit with idle
- 2024-12-15 如何用python代码实现手动输入两个数,并实现两个数的运算
- 2024-12-15 python一行代码打印「迷宫」建议收藏
- 2024-12-15 Python和C语言中的几个比较容易混淆的运算符号
- 2024-12-15 python 加、减、乘、除、乘方运算符
- 2024-12-15 python每天学习一点点(列表中+、*号、extend()方法的使用方法)
- 2024-12-15 简单学Python——内置函数22——range()函数
- 2024-12-15 用Python的numpy库进行线性拟合或者多项式拟合
- 05-25Python 3.14 t-string 要来了,它与 f-string 有何不同?
- 05-25Python基础元素语法总结
- 05-25Python中的变量是什么东西?
- 05-25新手常见的python报错及解决方案
- 05-2511-Python变量
- 05-2510个每个人都是需要知道Python问题
- 05-25Python编程:轻松掌握函数定义、类型及其参数传递方式
- 05-25Python基础语法
- 257℃Python短文,Python中的嵌套条件语句(六)
- 257℃python笔记:for循环嵌套。end=""的作用,图形打印
- 256℃PythonNet:实现Python与.Net代码相互调用!
- 251℃Python操作Sqlserver数据库(多库同时异步执行:增删改查)
- 251℃Python实现字符串小写转大写并写入文件
- 106℃原来2025是完美的平方年,一起探索六种平方的算吧
- 90℃Python 和 JavaScript 终于联姻了!PythonMonkey 要火?
- 81℃Ollama v0.4.5-v0.4.7 更新集合:Ollama Python 库改进、新模型支持
- 最近发表
- 标签列表
-
- python中类 (31)
- python 迭代 (34)
- python 小写 (35)
- python怎么输出 (33)
- python 日志 (35)
- python语音 (31)
- python 工程师 (34)
- python3 安装 (31)
- python音乐 (31)
- 安卓 python (32)
- python 小游戏 (32)
- python 安卓 (31)
- python聚类 (34)
- python向量 (31)
- python大全 (31)
- python次方 (33)
- python桌面 (32)
- python总结 (34)
- python浏览器 (32)
- python 请求 (32)
- python 前端 (32)
- python验证码 (33)
- python 题目 (32)
- python 文件写 (33)
- python中的用法 (32)