python类和实例以及__call__/__del__
面向对象最重要的概念就是类(Class)和实例(Instance),必须牢记类是抽象的模板,比如Student类,而实例是根据类创建出来的一个个具体的“对象”,每个对象都拥有相同的方法,但各自的数据可能不同。
创建实例是通过类名+()实现的
- 类是创建实例的模板,而实例则是一个一个具体的对象,各个实例拥有的数据都互相独立,互不影响;
- 方法就是与实例绑定的函数,和普通函数不同,方法可以直接访问实例的数据;
- 通过在实例上调用方法,我们就直接操作了对象内部的数据,但无需知道方法内部的实现细节。
- 和静态语言不同,Python允许对实例变量绑定任何数据,也就是说,对于两个实例变量,虽然它们都是同一个类的不同实例,但拥有的变量名称都可能不同
如图:Data1为类,Data1()为类的实例,Data1()()为调用类的实例。
__del__函数在删除实例时调用,析构方法,当对象被删除时,会自动被调用,然后释放内存;__call__在调用实例时被调用。
Data1()()创建了实例Data1(),同时调用了这个实例Data1()(),调用完,这个实例随即被删除
如下图:a是类Data1的实例,a()表示调用类的实例,这个时候实例a还存在,所以没有调用类的删除方法__del__。del a表示删除实例a,所以调用类的删除方法__del__
创建对象后,python解释器默认调用__init__()方法。当删除一个对象时,python解释器也会默认调用一个方法,这个方法为__del__()方法。在python中,对于开发者来说很少会直接销毁对象(如果需要,应该使用del关键字销毁)。Python的内存管理机制能够很好的胜任这份工作。也就是说,不管是手动调用del还是由python自动回收都会触发__del__方法执行
只有对象的引用计数变为0,这个对象才会被从内存里删除,才会调用对象的__del__方法。
import sys
sys.getrefcount(a) 获得对象a的引用计数
del 删除的是对象的引用,不是对象本身,当对象的引用为0是,对象会被垃圾回收掉
__call__():
Python中的函数是一级对象。这意味着Python中的函数的引用可以作为输入传递到其他的函数/方法中,并在其中被执行。 而Python中类的实例(对象)可以被当做函数对待。也就是说,我们可以将它们作为输入传递到其他的函数/方法中并调用他们,正如我们调用一个正常的函数那样。而类中__call__()函数的意义正在于此。为了将一个类实例当做函数调用,我们需要在类中实现__call__()方法。也就是我们要在类中实现如下方法:def __call__(self, *args)。这个方法接受一定数量的变量作为输入。
假设x是X类的一个实例。那么调用x.__call__(1,2)等同于调用x(1,2)。这个实例本身在这里相当于一个函数。
https://www.liaoxuefeng.com/wiki/001374738125095c955c1e6d8bb493182103fac9270762a000/00138682004077376d2d7f8cc8a4e2c9982f92788588322000
https://www.imooc.com/article/19040
https://blog.csdn.net/Yaokai_AssultMaster/article/details/70256621