day 33 反射机制,元类,__new__,__call__,元类下的属性查找。
1,内置方法在 满足某种条件下自动触发
2、python是动态,强类型的,解释型语言
动态:在程序中定义变量时不需要定义变量的类型,在执行时才知道变量的类型;静态:必须定义好变量的类型。
只要是动态语言,就必须有反射机制
解释:一句一句的翻译后执行
强类型:
3:反射
实现反射机制的步骤
1、先通过多dir:查看出某一个对象下可以.出哪些属性来
print(dir(obj))
2、可以通过字符串反射到真正的属性上,得到属性值
print(obj.__dict__[dir(obj)[-2]])
dir():查看某一对象的所有属性
hasattr:判断对象是否存在;
getattr:获取属性
setattr:赋值属性
delattr:删除属性
1 """
2 @作者: egon老湿
3 @微信:18611453110
4 @专栏: https://zhuanlan.zhihu.com/c_1189883314197168128
5 """
6
7 # 什么是反射?
8 # 指的是在程序运行过程中可以"动态(不见棺材不掉泪)"获取对象的信息
9
10 # 为何要用反射?
11
12 # 如何实现反射?
13 class People:
14 def __init__(self,name,age):
15 self.name=name
16 self.age=age
17
18 def say(self):
19 print('<%s:%s>' %(self.name,self.age))
20
21 obj=People('辣白菜同学',18)
22
23
24
25 # 实现反射机制的步骤
26 # 1、先通过多dir:查看出某一个对象下可以.出哪些属性来
27 # print(dir(obj))
28
29 # 2、可以通过字符串反射到真正的属性上,得到属性值
30 # print(obj.__dict__[dir(obj)[-2]])
31
32 # 四个内置函数的使用:通过字符串来操作属性值
33 # 1、hasattr()
34 # print(hasattr(obj,'name'))
35 # print(hasattr(obj,'x'))
36
37 # 2、getattr()
38 # print(getattr(obj,'name'))
39
40 # 3、setattr()
41 # setattr(obj,'name','EGON') # obj.name='EGON'
42 # print(obj.name)
43
44 # 4、delattr()
45 # delattr(obj,'name') # del obj.name
46 # print(obj.__dict__)
47
48
49 # res1=getattr(obj,'say') # obj.say
50 # res2=getattr(People,'say') # People.say
51 # print(res1)
52 # print(res2)
53
54
55 # obj=10
56 # if hasattr(obj,'x'):
57 # print(getattr(10,'x'))
58 # else:
59 # pass
60
61 # print(getattr(obj,'x',None))
62
63
64 # if hasattr(obj,'x'):
65 # setattr(obj,'x',111111111) # 10.x=11111
66 # else:
67 # pass
68
69
70 class Ftp:
71 def put(self):
72 print('正在执行上传功能')
73
74 def get(self):
75 print('正在执行下载功能')
76
77 def interactive(self):
78 method=input(">>>: ").strip() # method='put'
79
80 if hasattr(self,method):
81 getattr(self,method)()
82 else:
83 print('输入的指令不存在')
84
85
86 # obj=Ftp()
87 # obj.interactive()
打映对象会触发__str__,内置方法。print(obj)
__del__:在删除对象时会先执行
程序结束了,需要释放内存空间,释放内存空间就包括删除变量,所以__del__ 在print函数执行完了在执行
对象占据内存空间,但是他的某个方法或者属性可能占据操作系统资源
对象删除之前告诉系统占据的系统资源没有用了,这是__del__ 的一个用处
1 """
2 @作者: egon老湿
3 @微信:18611453110
4 @专栏: https://zhuanlan.zhihu.com/c_1189883314197168128
5 """
6
7
8 # 1、什么是内置方法?
9 # 定义在类内部,以__开头并以__结果的方法
10 # 特点:会在某种情况下自动触发执行
11
12 # 2、为何要用内置方法?
13 # 为了定制化我们的类or对象
14
15 # 3、如何使用内置方法
16 # __str__:在打印对象时会自动触发,然后将返回值(必须是字符串类型)当做本次打印的结果输出
17 # class People:
18 # def __init__(self, name, age):
19 # self.name = name
20 # self.age = age
21 #
22 # def __str__(self):
23 # # print('运行了...')
24 # return "<%s:%s>" %(self.name,self.age)
25 #
26 #
27 # obj = People('辣白菜同学', 18)
28 #
29 # # print(obj.__str__())
30 # print(obj) # <'辣白菜同学':18>
31 #
32 # # obj1=int(10)
33 # # print(obj1)
34
35 # __del__:在清理对象时触发,会先执行该方法
36 class People:
37 def __init__(self, name, age):
38 self.name = name
39 self.age = age
40 self.x = open('a.txt',mode='w')
41 # self.x = 占据的是操作系统资源
42
43 def __del__(self):
44 # print('run...')
45 # 发起系统调用,告诉操作系统回收相关的系统资源
46 self.x.close()
47
48 obj = People('辣白菜同学', 18)
49 # del obj # obj.__del__()
50 print('============>')
元类介绍
如何得到对象,调用类()
如果说类也是对象,那么为了得到类对象,也需要调用类()。这个类的类叫做元类。用来实例化产生类的类
流程:关系:元类---实例化---->类(People)---实例化---->对象(obj)
查看对象的类是什么?print(type(obj)).相同的得到类的类,元类:print(type(类))
查看内置的元类:
1、type是内置的元类
2、我们用class关键字定义的所有的类以及内置的类都是由元类type实例化产生
print(type(People))
class 创造类,底层一定调用了type(),让后把他传给了people
type()接受了那些参数呢?
1、类名 2、类的基类(父类) 3、类体。一堆字符串
创造类,默认继承元类
只有继承了type类的类才是元类
主动报错 raise、
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人