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、

 

posted @   晏雷雨  阅读(16)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
点击右上角即可分享
微信分享提示