Python 3 面向对象进阶
一、 isinstance(obj,cls)和issubclass(sub,super)
isinstance(obj,cls)检查是否obj是否是类 cls 的对象
class Foo(object): passobj = Foo()isinstance(obj, Foo)issubclass(sub, super)检查sub类是否是 super 类的派生类class Foo(object): passclass Bar(Foo): passissubclass(Bar, Foo)
二 反射
反射的概念是由Smith在1982年首次提出的,主要是指程序可以访问、检测和修改它本身状态或行为的一种能力(自省)。这一概念的提出很快引发了计算机科学领域关于应用反射性的研究。它首先被程序语言的设计领域所采用,并在Lisp和面向对象方面取得了成绩。
python面向对象中的反射:通过字符串的形式操作对象相关的属性。python中的一切事物都是对象(都可以使用反射)
class Foo: x=1 def __init__(self,name): self.name=name def f1(self): print('from f1')print(Foo.x) #Foo.__dict__['x'] f=Foo('egon')print(f.__dict__) #1:print(f.name) #2:print(f.__dict__['name'])
四个可以实现反射的函数:hasattr,getattr,setattr,delattr
# hasattrclass Foo: x=1 def __init__(self,name): self.name=name def f1(self): print('from f1')print(Foo.x) #Foo.__dict__['x']f=Foo('egon') print(hasattr(f,'name')) #f.nameprint(hasattr(f,'f1')) #f.f1print(hasattr(f,'x')) #f.x #setattrsetattr(f,'age',18)#f.age=18 #getattrprint(getattr(f,'name'))#f.nameprint(getattr(f,'abc',None))#f.abcprint(getattr(f,'name',None))#f.abc func=getattr(f,'f1')#f.f1print(func)func()
为什么用反射之反射的好处
好处一:实现可插拔机制可以实现把主要的逻辑写好(只定义接口),然后后期再去实现接口的功能
好处二:动态导入模块