__del__:
- 被称为析构函数
- 当删除一个对象时,python解释器会默认调用__del__()方法
import gc
class Dog(object):
def __init__(self,name):
self.name=name
def __del__(self):
print("删除成功")
def wang(self):
print("汪汪汪")
d1=Dog("小黑")
d1.wang()
# d1=None
# del d1
#以上两种都可以删除,或者程序结束也会释放内存
# d1.wang()#删除后这里会报错
__doc__ :
class Dog:
"""这是这个类的说明
"""
def __init__(self,name):
self.name=name
d1=Dog("奥巴马")##创建对象,传入__init__所需的变量,self默认自动传入
print(Dog.__doc__)
--------------------------
结果:
这是这个类的说明
__dict__ :
class Dog:
#self 代表的是类的实例,代表当前对象的地址
def __init__(self,name):##称为类的构造函数,进行初始化成员变量
self.name=name
def bulk(self):###自定义函数
print("%s:汪汪!"%self.name)
d1=Dog("奥巴马")##创建对象,传入__init__所需的变量,self默认自动传入
print(Dog.__dict__)###类相关的变量,函数
print(d1.__dict__)##只有自身的实例变量
-----------------------------------------
{'__module__': '__main__', '__init__': <function Dog.__init__ at 0x000002B6950FC9D8>, 'bulk': <function Dog.bulk at 0x000002B6950FCA60>, '__dict__': <attribute '__dict__' of 'Dog' objects>, '__weakref__': <attribute '__weakref__' of 'Dog' objects>, '__doc__': None}
{'name': '奥巴马'}
__module__:
- 类定义所在的模块:源文件中会显示__main__,导入为模块时为类定义所在的模块
__getitem__:
- 凡是在类中定义了这个__getitem__ 方法,那么它的实例对象(假定为p),可以像这样 p[key] 取值,当实例对象做p[key] 运算时,会调用类中的方法__getitem__。

__setitem__:
- 使对象可以使用obj[key]=value来调用__setitem__进行操作

__delitem__:

class A(object):
def __getitem__(self, key):
print('__getitem__', key)
def __setitem__(self, key, value):
self.value=value
print('__setitem__', key, value)
def __delitem__(self, key):
print('__delitem__', key)
obj = A()
result = obj['k1'] # 触发__getitem__
obj['k2'] = 'neo' # 触发__setitem__
print(obj.value) #设置的可以获取
del obj['k1'] #触发__delitem__
__str__:

class Dog(object):
def __init__(self,name):
self.name=name
def __str__(self):
return self.name
d=Dog("apple")
print(d)
class Dog(object):
def __init__(self,name):
self.name=name
def __str__(self):
return "这是一个?"
d=Dog("apple")
print(d)
__call__:
- 一个类实例也可以变成一个可调用对象,只需要实现一个特殊方法__call__()。

class call_test(object):
def __call__(self, *args, **kwargs):
print("hello ",args,kwargs)
c=call_test()
c()