Python进阶-XVIV 类的内置方法:__str__ 、__repr__、析构函数(__del__)、双下的call,eq,new,hash 以及item相关的三个方法
类的内置方法
它与内置函数有紧密的联系,有的内置函数就是调用的内置方法。
在顶级父类obj中有:
两个双下方法
obj.__str__ str(obj)
obj.__repr__ repr(obj)
1、__str__ 与 __repr__
class Teacher:
def __init__(self, name, salary):
self.name = name
self.salary = salary def __str__(self):
return "Teacher's object :%s" % self.name def __repr__(self):
return str(self.__dict__) def func(self):
return 'wahaha' nezha = Teacher('哪吒', 250)
print(nezha) # 打印一个对象的时候,就是调用a.__str__
print(repr(nezha))
print('>>> %r' % nezha)
a.__str__ --> object
object 里有一个__str__,一旦被调用,就返回调用这个方法的对象的内存地址
l = [1,2,3,4,5] # 实例化 实例化了一个列表类的对象
print(l)
%s str() 直接打印 实际上都是走的__str__
%r repr() 实际上都是走的__repr__
repr 是str的备胎,但str不能做repr的备胎
print(obj)/'%s'%obj/str(obj)的时候,实际上是内部调用了obj.__str__方法,如果str方法有,那么他返回的必定是一个字符串
如果没有__str__方法,会先找本类中的__repr__方法,再没有再找父类中的__str__。
repr(),只会找__repr__,如果没有找父类的
内置的方法有很多,但是不一定全都在object中
class Classes:
def __init__(self, name):
self.name = name
self.student = [ ] def __len__(self):
return len(self.student) # obj中没有该方法,因为obj只存所有对象共有的! def __str__(self):
return 'classes' py_s9 = Classes('九年级三班')
py_s9.student.append('董青')
py_s9.student.append('久美')
print(len(py_s9))
print(py_s9) # 1、__str__
print(str(12)) # 其实就是调用int类型的__str__方法 # 为了验证,可以来一个例子:
class StrDemo:
def __init__(self, name):
self.name = name # def __str__(self):
# print('调用我的str双下方法了!')
# return self.name
def __repr__(self):
print('调用我的repr双下方法了!')
return self.name s = StrDemo("string")
print(str(s)) # 2、__repr__
print(repr(''))
print(repr(1))
# 我们将StrDemo类中的__str__方法注释掉,看看发生什么?
print(repr(s)) # 当一个类没有重写__str__方法,但是重写了__repr__方法,当使用str(本类实例)的时候,就调用了__repr__
# 即__repr__是__str__的备胎,但是反过来就不行!
2、析构函数(__del__)
功能是在回收内存中的对象,并在回收前做一些收尾工作,如打开的文件没关闭,将其关闭等!
class A:
def __init__(self, f):
self.f = f def __del__(self):
print('it deling')
self.f.close() # 析构函数: 在删除一个对象之前进行一些收尾工作 a = A(open('2_反射进阶.py'))
del a # del 既执行了这个方法,又删除了变量 # del a NameError: name 'a' is not defined # 引用计数中用到该内置方法
3、item相关方法:__getitem__ __setitem__ __delitem__
class Person:
def __init__(self, name,age,ginder):
self.name = name
self.age = age
self.ginder = ginder def __getitem__(self, item):
if hasattr(self, item):
return self.__dict__[item] def __setitem__(self, key, value):
self.__dict__[key] = value def __delitem__(self, key):
print('it is calling me !')
self.__dict__.pop(key) tom = Person('tom', 22, 'male')
# 得到属性
print(tom['ginder']) # __getitem__可以用访问字典中的元素一样访问对象的属性!
# 设置属性
tom['kind'] = 'superman'
print(tom.kind, tom['kind'])
#del tom.kind # object 原生支持 __delattr__
del tom['kind'] # 通过自己实现的
print(tom.kind, tom['kind'])
4、__hash__ 对应 hash()内置函数
查看hash值,可以修改hash规则,是的本来有不同hash值的两个对象有一样的hash值
lass Hash:
def __init__(self, name):
self.name = name def __hash__(self):
return hash(self.name) ha_a = Hash('a_Hash')
hah = Hash('a_Hash')
print(hash(ha_a), hash(hah)) # 两个对象虽然名字一样,但是hash值不同:-9223371888545262739 148309513073
# 实现object中的__hash__方法,并只返回name的hash值,就相等了:-9184190014575666570 -9184190014575666570
5、__new__ 构造函数,在初始化函数前,将self构造出来。
  典型使用:单例模式(23种设计模式第一个)
  即:一个类在内存中,始终只有一个实例
  __init__ 初始化方法
  __new__  构造方法 : 创建一个对象
class Singleton():
__instance = False
def __init__(self, name):
self.name = name def __new__(cls, *args, **kwargs):
'''实现单例'''
if cls.__instance:
return cls.__instance
else:
cls.__instance = object.__new__(cls)
return cls.__instance a = Singleton('a')
a.nm = '单例'
b = Singleton('b')
print(b.nm)
print(id(a), id(b)) # 没有实现__new__方法前的结果是:2681905465888 2681905467232 地址不同,说明是两个对象
# __实现__new__方法后,即使不写具体操作,直接pass,也返回相同的地址:1760945392 1760945392
# 实现单例的操作后,地址变为:2491487242000 2491487242000 还是相同,即为同一对象!
6、 __eq__方法
class Equal:
def __init__(self, name):
self.name = name def __eq__(self, other):
if self.name == other.name:
return True double_eq = Equal('双等于号')
eq = Equal('双等于号')
# 问:两个对象相等吗?
print(double_eq, eq, double_eq == eq)
# <__main__.Equal object at 0x0000027726CA3828> <__main__.Equal object at 0x0000027726CA3860> False
# 内存地址不一样,是两个对象,所以不等,双下eq方法,是继承自顶级的object类,原来就是比较内存地址的!
# 实现该方法的其他类,如str,int等,改为值等就是相等了!
# 如何让两个相同的名字的Equal对象,变为相等了?只有重写eq方法了
print(double_eq == eq)
7、__call__ 方法
class B:
def __init__(self, name):
self.name = name def __call__(self):
for k in self.__dict__:
print(k, self.__dict__[ k ]) B('sb')() # 最后一个()就是在调用该类中的双下call方法!
Python进阶-XVIV 类的内置方法:__str__ 、__repr__、析构函数(__del__)、双下的call,eq,new,hash 以及item相关的三个方法的更多相关文章
- 二十六. Python基础(26)--类的内置特殊属性和方法
		
二十六. Python基础(26)--类的内置特殊属性和方法 ● 知识框架 ● 类的内置方法/魔法方法案例1: 单例设计模式 # 类的魔法方法 # 案例1: 单例设计模式 class Teacher: ...
 - Python进阶之浅谈内置方法(补充)
		
目录 列表类型的内置方法 元组类型的内置方法 字典类型的内置方法 集合类型的内置方法 列表类型的内置方法 1.作用:描述名字,说的话等 2.定义方式 s=['tim','age'] s=str('ti ...
 - Python进阶之浅谈内置方法
		
目录 有序or无序和可变or不可变 数字类型内置方法 整形 浮点型 字符串类型内置方法 有序or无序和可变or不可变 有序:有索引 无序:无索引 可变:变量值变,id不变 不可变:变量值变,id也变 ...
 - python进阶之py文件内置属性
		
前言 对于任何一个python文件来说,当python解释器运行一个py文件,会自动将一些内容加载到内置的属性中:一个模块我们可以看做是一个比类更大的对象. 查看模块的内置属性 我们先创建一个典型的p ...
 - python基础(14)-反射&类的内置函数
		
反射 几个反射相关的函数可参考python基础(10)-匿名函数&内置函数中2.2.4反射相关 类的一些内置函数 __str__()&__repr__() 重写__str__()函数类 ...
 - Python学习day08-python进阶(2)-内置方法
		
Python学习day08-python进阶(2)-内置方法 列表数据类型内置方法 作用 描述多个值,比如爱好 定义方法 xxxxxxxxxx 2 1 hobby_list ...
 - python学习之老男孩python全栈第九期_day027知识点总结——反射、类的内置方法
		
一. 反射 ''' # isinstance class A:pass class B(A):pass a = A() print(isinstance(a,A)) # 判断对象和类的关系 print ...
 - python基础语法18   类的内置方法(魔法方法),单例模式
		
类的内置方法(魔法方法): 凡是在类内部定义,以__开头__结尾的方法,都是类的内置方法,也称之为魔法方法. 类的内置方法,会在某种条件满足下自动触发. 内置方法如下: __new__: 在__ini ...
 - python -- 类中--内置方法
		
isinstance 和 issubclass isinstance(obj,b) 检查是否obj是否是类b的对象 class A(object):pass class B(A):pass b=B ...
 
随机推荐
- leetcode 752. 打开转盘锁
			
地址 https://leetcode-cn.com/problems/open-the-lock/ 你有一个带有四个圆形拨轮的转盘锁.每个拨轮都有10个数字: '0', '1', '2', '3', ...
 - HttpClient基本功能的使用 Get方式
			
一.GET 方法 使用 HttpClient 需要以下 6 个步骤: 1. 创建 HttpClient 的实例 2. 创建某种连接方法的实例,在这里是 GetMethod.在 ...
 - Leetcode 153. 寻找旋转排序数组中的最小值
			
假设按照升序排序的数组在预先未知的某个点上进行了旋转. ( 例如,数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1,2] ). 请找出其中最小的元素. 你可以假设数组中不存在重 ...
 - nowcoder3274D binary
			
题目链接 problem 给定一个01串s,定义rev(x)表示逐位翻转(0变1,1变0)x后并删去前导零后所得到的串.好的串定义如下: s是好的串 如果x是好的串,则rev(x)也是好的串 如果a, ...
 - Note | 常用指令,工具,教程和经验笔记
			
目录 图像处理 机器学习和数学 编程环境和工具 写作工具 其他 图像处理 获取图像频域并分解为高低频:https://www.cnblogs.com/RyanXing/p/11630493.html ...
 - Linux 学习记录五(软件的安装升级).
			
一.gcc gcc是Linux上面最标准的C语言的编译程序,用来源代码的编译链接. gcc -c hello.c 编译产生目标文件hello.o gcc -O hello.c 编译产生目标文件,并进行 ...
 - Jenkins操作学习 -- 配置及使用
			
一.jenkins基本配置 1.在Jenkins首页,点击Manage Jenkins,然后再点击Manage Plugins插件管理,安装必要的插件.这里我只需要安装Git,因为第一次初始化安装没成 ...
 - flex布局和边框阴影
			
"妄"眼欲穿-CSS之flex布局和边框阴影 妄:狂妄: 不会的东西只有怀着一颗狂妄的心,假装能把它看穿吧. flex布局 main axis:主轴:cross axis:交叉轴 ...
 - 数据库——SQL SERVER Transact-SQL  程序设计
			
什么是Transact-SQL? 标准SQL不支持过程化控制, 不能完成复杂的功能.T-SQL是过程化SQL语言, 是SQL的扩展 增加了过程化语句 (变量,赋值,分支,循环...)是数据库服务器 ...
 - python基础(31):进程(一)
			
1. 什么是进程 进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础.在早期面向进程设计的计算机结构中,进程是程序的基本执行 ...