反射

反射:通过字符串来映射到对象的属性

class People():
def __init__(self, name, age):
self.name = name
self.age = age def talk(self):
print('Name:%s,Age:%s' % (self.name, self.age)) p = People('ysg', 21) # 判断 对象 中是否存在该属性,实际判断的是 p.__dict__ ['name']
print(hasattr(p, 'name')) # 结果:True # 取到 'name' 中的值
print(getattr(p, 'name', None)) # 结果:ysg
print(getattr(p, 'names', None)) # 结果:None
print(getattr(p, 'talk', None)) # <bound method People.talk of <__main__.People object at 0x0000020EDF705278>> # 修改 'name' 中的值
setattr(p, 'name', 'ysging') # p.name = 'ysging'
print(p.name) # 结果:ysging # 删除 'name' 对象
delattr(p, 'age') # del p.age
print(p.__dict__) # 结果:{'name': 'ysging'}

有这样的需求:希望通过用户的输入内容来调用方法

例子

class People():
def __init__(self, name, age):
self.name = name
self.age = age def run(self):
while 1:
val = input('>>>')
if hasattr(self, val):
func = getattr(self, val, None)
func()
def talk(self):
print('Name:%s,Age:%s' % (self.name, self.age)) p = People('ysg', 21)
p.run() # 结果
# >>>talk
# Name:ysg,Age:21

反射的好处:

好处一:实现可插拔机制

有俩程序员,一个lili,一个是egon,lili在写程序的时候需要用到egon所写的类,但是egon去跟女朋友度蜜月去了,还没有完成他写的类,lili想到了反射,使用了反射机制lili可以继续完成自己的代码,等egon度蜜月回来后再继续完成类的定义并且去实现lili想要的功能。

总之反射的好处就是,可以事先定义好接口,接口只有在被完成后才会真正执行,这实现了即插即用,这其实是一种‘后期绑定’,什么意思?即你可以事先把主要的逻辑写好(只定义接口),然后后期再去实现接口的功能

好处二:动态导入模块(基于反射当前模块成员)

内置方法

isinstance(obj,cls) 检查是否 obj 是否是类 cls 的对象

class Foo():
pass obj = Foo()
g = 123
print(isinstance(obj, Foo)) # True
print(isinstance(g, Foo)) # False

issubclass(sub, super) 检查 sub 类是否是 super 类的派生类

class Foo():
pass class A(Foo):
pass class B():
pass print(issubclass(A, Foo)) # True
print(issubclass(B, Foo)) # False

item 系列:把对象做成像字典的类型

class Foo():
def __init__(self, name):
self.name = name def __getitem__(self, item):
print('getitem...')
return self.__dict__.get(item) def __setitem__(self, key, value):
print('setitem...')
print(key,value) # name ysging
self.__dict__[key] = value def __delitem__(self, key):
del self.__dict__[key] f = Foo('ysg')
print(f.__dict__) # {'name': 'ysg'} # 取值
print(f['name']) # ysg # 设置
f['name'] = 'ysging'
print(f.name) # ysging # 删除
del f['name']
print(f.__dict__) # {}

__str__

一般情况下打印出为内存地址

class People():
def __init__(self, name, age):
self.name = name
self.age = age p = People('ysg', 22)
print(p) # <__main__.People object at 0x000002C168D952E8>

使用 __str__ 后,打印结果可以自定义

class People():
def __init__(self, name, age):
self.name = name
self.age = age def __str__(self):
return '<name:%s,age:%s>' % (self.name, self.age) p = People('ysg', 22)
print(p) # <name:ysg,age:22>

__del__:如果在类内部定义了一个 __del__ 方法,则会在对象被删除的时候先自动触发这个方法,再把对象删掉

python只会回收对象本身的资源,不会回收与对象相关的数据

class Open():
def __init__(self,file):
print('open file...')
self.file = file def __del__(self):
print('回收与对象相关的资源:self.close()') #这里可以写上与对象相关的数据,如:操作系统中的资源 f = Open('config.py')
print('-------main-------')

析构方法,当对象在内存中被释放时,自动触发执行。

注:如果产生的对象仅仅只是python程序级别的(用户级),那么无需定义__del__,如果产生的对象的同时还会向操作系统发起系统调用,即一个对象有用户级与内核级两种资源,比如(打开一个文件,创建一个数据库链接),则必须在清除对象的同时回收系统资源,这就用到了__del__

典型的应用场景:

创建数据库类,用该类实例化出数据库链接对象,对象本身是存放于用户空间内存中,而链接则是由操作系统管理的,存放于内核空间内存中

当程序结束时,python只会回收自己的内存空间,即用户态内存,而操作系统的资源则没有被回收,这就需要我们定制__del__,在对象被删除前向操作系统发起关闭数据库链接的系统调用,回收资源

day 27-1 反射、内置方法的更多相关文章

  1. 多态 鸭子类型 反射 内置方法(__str__,__del__) 异常处理

    ''' 1什么是多态 多态指的是同一种/类事物的不同形态 2 为何要有多态 多态性:在多态的背景下,可以在不用考虑对象具体类型的前提下而直接使用对象 多态性的精髓:统一 多态性的好处: 1增加了程序的 ...

  2. python基础之反射内置方法元类

    补充内置函数 isinstance(obj,Foo)   # 判断obj是不是foo的实例 issubclass()      # 判断一个类是不是另一个类的子类 反射 什么是反射? 通过字符串来操作 ...

  3. 27 isinstance与issubclass、反射、内置方法

    isinstance与issubclass issubclass:判断子类是否属于父类,是则返回True,否则返回False isinstance:判断对象是否属于类,是则返回True,否则返回Fal ...

  4. Python之面向对象之反射、内置方法

    一.静态方法(staticmethod)和类方法(classmethod) 类方法:有个默认参数cls,并且可以直接用类名去调用,可以与类属性交互(也就是可以使用类属性) 静态方法:让类里的方法直接被 ...

  5. day28 面向对象:反射,内置函数,类的内置方法

    面向对象进阶博客地址链接: http://www.cnblogs.com/Eva-J/articles/7351812.html 复习昨日内容: # 包 # 开发规范 # # hashlib # 登录 ...

  6. 反射与内置方法str del

    1.反射 用字符串来操作类或者对象的属性 class People:# country= 'china'# def __init__(self,name):# self.name= name## de ...

  7. Learning-Python【26】:反射及内置方法

    反射的概念 可以用字符串的方式去访问对象的属性,调用对象的方法(但是不能去访问方法),Python 中一切皆对象,都可以使用反射. 反射有四种方法: hasattr:hasattr(object, n ...

  8. python day21 ——面向对像-反射 getattr,内置方法

    一.反射:用字符串数据类型的变量名来访问这个变量的值 上代码^_^ # class Student: # ROLE = 'STUDENT' # @classmethod # def check_cou ...

  9. python 入门基础21 --面向对象_多态、内置方法、反射

    内容: 1.接口思想 2.抽象类思想 3.多态 4.内置方法 5.反射 1.接口思想 建立关联的桥梁,方便管理代码 接口类:用来定义功能的类,位继承它的子类提供功能 该类的功能方法一般不需要实现体,实 ...

  10. python面向对象 : 反射和内置方法

    一. 反射 1. isinstance()和issubclass() isinstance( 对象名, 类名) : 判断对象所属关系,包括父类  (注:type(对象名) is 类名 : 判断对象所属 ...

随机推荐

  1. 不给糖果就捣乱,用Python绘制有趣的万圣节南瓜怪【华为云分享】

    关于万圣节 万圣节又叫诸圣节,在每年的11月1日,是西方的传统节日:而万圣节前夜的10月31日是这个节日最热闹的时刻.在中文里,常常把万圣节前夜(Halloween)讹译为万圣节(All Saints ...

  2. React 事件总结

    目录 一 绑定事件处理函数 1.1 鼠标类 1.2 拖拽事件: 1.3 触摸 1.4 键盘 1.5 剪切类 1.6 表单类 1.7 焦点事件 1.8 UI元素类 1.9 滚动 1.10 组成事件 1. ...

  3. HDU3870- intervals(差分约束)

    You are given n closed, integer intervals [ai, bi] and n integers c1, ..., cn. Write a program that: ...

  4. 适用于Java开发人员的SOLID设计原则简介

    看看这篇针对Java开发人员的SOLID设计原则简介.抽丝剥茧,细说架构那些事——[优锐课] 当你刚接触软件工程时,这些原理和设计模式不容易理解或习惯.我们都遇到了问题,很难理解SOLID + DP的 ...

  5. 【Oracle】ORA-12560: TNS: 协议适配器错误

    问题现象: ORA-12560: TNS: 协议适配器错误 解决方法: 启动监听服务

  6. 设置QQ环境变量

    1.右击此电脑 → 属性 win10用户可以直接按 'win'键 ,输入 "系统环境变量" 2.点击 高级系统环境设置 → 环境变量 3.在系统变量里找到 path → 编辑 4. ...

  7. 对 HTML 语义化的理解

    简述一下你对 HTML 语义化的理解? 用正确的标签做正确的事情. html 语义化让页面的内容结构化,结构更清晰,便于对浏览器.搜索引擎解析; 即使在没有样式 CSS 情况下也以一种文档格式显示,并 ...

  8. JAVA 锁的终极状态

    自旋锁 背景:互斥同步对性能最大的影响是阻塞,挂起和恢复线程都需要转入内核态中完成:并且通常情况下,共享数据的锁定状态只持续很短的一段时间,为了这很短的一段时间进行上下文切换并不值得. 原理:当一条线 ...

  9. windows10查看电脑已经保存的wifi密码

    1,打开windows的命令窗口,输入    netsh wlan show profiles,如下图,这个命令仅仅只是查看一下电脑保存的所有的wifi名字 2,需要查看密码的话,则需要输入这个命令, ...

  10. laravel55

    增//save返回true false$res = new member();res->username = 'a';$res->password = 'b';dump($res-> ...