__str__ : str(obj) , 需求必须实现了 __str__, 要求这个方法的返回值必须是字符串 str 类型
__repr__ (意为原型输出): 是 __str__ 的备胎(在找不到__str__的时候返回__repr__) ,吐过有__str__方法, 那么先去执行__str__ 方法 并使用__str__ 的返回值. 如果没有__str__ 那么print %s str 都会执行 repr.
注意:
#在子类中使用__str__ , 先找子类的__str__ ,没有的话要向上找, 只要父类不是objict,就执行父类中的__str__但是如果除了objict之外的父类都没有__str__方法,就执行子类的__repr__方法, 如果子类也没有,就要向上继续找父类中的__repr__方法. 直到找不到为止,再去执行object类中的__str__方法.
例如:
class A:
def __init__(self, name):
self.name = name
def __str__(self): # 定义字符串
return ' **%s** ' % self.name
def __repr__(self):
return self.name
class B(A):
def __repr__(self):
return '***'
a = B('alex')
print(a)
print(str(a), repr(a))
print('%s|%r' % (a, a))
构造方法 申请一个空间 (操作系统分配的)
析构方法 释放一个空间之前执行
某对象借用了操作系统的资源还要通过析构方噶归还回去 : 1 文件资源 2 网络资源( 1 2 位应用范围 )
垃圾回收机制:
class A:
def __del__(self):
# 析构算法 del A 的对象 会自动触发这个方法
print(' 执行我了 ')
a = A()
del a # 对象的删除 del
print(a)
*********************************************
class File():
# 处理文件的时候
def __init__(self, file_path):
self.f = open(file_path)
self.name = 'alex' # 相当于普通字段
def read(self):
self.f.read(1024)
def __del__(self):
# 此处的__del__是去归还 / 释放一些在创建对象时调用的一些资源
# del 对象的时候 需要程序员去触发(人自己写)
# python解释器的垃圾回收机制 回收这个对象所占的内存空间的时候 是python自动触发的
self.f.close() # 文件操作符 此处如果不进行这项操作, 系统的文件资源会一直被调用 而不会关闭.所以此处要定义次操作.
f = File('文件名')
f.read()
不管是主动还是被动,这个f 对象总会被清理掉, 被清理掉就会触发__del__ 方法, 触发这个方法就会归还操作系统的文件资源.
# 在文件操作中,
f = open ('wenjian')
# 其操作流程为: python -------> 操作系统 ---------> 硬盘里的文件 ----------> 文件操作符
f.close() 稳健操作符