一. 初始化方法__init__
(类中)
··当使用 类名() 创建对象时,会执行以下的操作:
1.为对象在内存中分配空间–创建对象
2.为对象的属性设置初始值–初始化方法(init
)
··这个初始化方法就是 __init__
方法,__init__
方法是对象的内置方法
__init__
方法是专门用来定义一个类具有哪些属性的方法
例:
二. 对象销毁时方法 __def__
(类中)
如果希望在对象销毁前,再做一些事情,可以使用
__def__
方法
例:
三. __str__
方法(类中)
··在用print输出对象变量时,默认情况下会输出变量引用的对象是由哪个类创建的以及在内存中的地址(十六进制表示)
··如果在开发中,希望使用print输出对象变量时,能够输出自定义打印的内容,可以利用__str__
这个内置方法
注:
__str__
方法必须返回一个字符串
例:
四. 方法搜索顺序__mro__
(类中)
● Python 中针对类提供了一个内置属性__mro__
可以查看方法搜索顺序
● MRO 是method resolution order
,主要用于在多继承时判断方法、属性的调用路径
例:
●在搜索方法时,是按照__mro__
的输出结果从左至右的顺序查找的
●如果在当前类中找到方法,就直接执行,不再搜索
●如果没有找到,就查找下一个类中是否有对应的方法,如果找到,就直接执行,不再搜索
●如果找到最后一个类,还没有找到方法,程序报错
五. 为对象分配空间__new__
方法(类中)
●使用 类名()创建对象 时,Python 的解释器首先会调用__new__
方法为对象分配空间
●__new__
是一个由 object 基类提供的内置的静态方法, 主要作用有两个:
1)在内存中为对象分配空间
2)返回对象的引用
● Python的解释器获得对象的引用后,将引用作为第一个参数,传递给__init__
方法
注:重写
__new__
方法的代码非常固定!
●重写__new__
方法一定要return super().__new__(cls)
●否则Python的解释器得不到分配了空间的对象引用,就不会调用对象的初始化方法
注:
__new__
是一个静态方法, 在调用时需要主动传递 cls 参数
例:
·
六. __name__
内置属性
为了解决 在导入模块时会自动运行该模块的测试代码,使用内置属性__name__
将测试代码只在测试情况下会被调用,被导入时不会被调用。
·
●__name__
是Python 的一个内置属性,记录着一个字符串
●如果是被其他文件导入的,__name__
就是 模块名
●如果是当前执行的程序__name__
是__main__
例1:
例2:
标准写法:
`
六. 查看模块的完整路径__file__
内置属性
Python的解释器在导入模块时,会:
1.搜索当前目录指定模块名的文件,如果有就直接导入
2.如果没有,再搜索系统目录
Python中每一个模块都有一个内置属性__file__
可以查看模块的完整路径
例:
·
七. 迭代器__iter__()
方法
如果想要一个对象 成为可迭代的对象,即可以使用for进行遍历,那么必须实现__iter__()
方法。
在调用__iter__()
方法后返回的对象是一个迭代器,而在返回的对象中必须含有__next__()
方法,在每次遍历时得到的结果其实就是__next__()
方法的返回值。
·
八. 导入自定义模块__import__()
方法
在python中平常用
import + 模块名
如果这里在import后面加变量 import+变量
则会在路径中直接找该变量名,如果用__import__(变量)会先解析该变量,再去引入解析后的模块名
__import__(变量)
这里会对变量进行解析,将解析后的名字带到路径中寻找并引入
·
九. 对象后面加括号调用__call__()
方法
对象后面加括号->触发执行
例:
class test():
def __init__(self):
pass
def __call__(self, *args, **kwargs):
print("__call__")
obj = test() # 执行__init__()
obj() # 执行__call__()