面向对象的继承和多态,剖析对象的信息(获取相关信息),类属性和实例属性
发布日期:2021-06-29 11:42:46 浏览次数:2 分类:技术文章

本文共 2155 字,大约阅读时间需要 7 分钟。

继承:当定义一个class的时候,可以从某个现有的class继承,新的class称为子类(Subclass),而被继承的class称为基类、父类或超类(Base class、Super class)。继承有什么好处?最大的好处是子类获得了父类的全部功能。继承的第二个好处需要我们对代码做一点改进。

多态:当子类和父类都存在相同的方法时,我们说,子类的方法覆盖了父类的方法,在代码运行的时候,总是会调用子类的方法。这样,我们就获得了继承的另一个好处:多态。

多态真正的威力:调用方只管调用,不管细节,而当我们新增一种Animal的子类时,只要确保run()方法编写正确,不用管原来的代码是如何调用的。这就是著名的“开闭”原则:(1)对扩展开放:允许新增Animal子类;(2)对修改封闭:不需要修改依赖Animal类型的run_twice()等函数。

获取信息所使用到的方法有:

1.:对于class的继承关系来说,使用type()就很不方便。我们要判断class的类型,可以使用isinstance()函数。isinstance()就可以告诉我们,一个对象是否是某种类型。

2.dir()函数:获得一个对象的所有属性和方法,可以使用dir()函数,它返回一个包含字符串的list。

3.操作属性和方法的状态:仅仅把属性和方法列出来是不够的,配合getattr()setattr()以及hasattr(),我们可以直接操作一个对象的状态

hasattr(obj, 'x') # 有属性'x'吗? #  Trueobj.x# 9hasattr(obj, 'y') # 有属性'y'吗?# Falsesetattr(obj, 'y', 19) # 设置一个属性'y'hasattr(obj, 'y') # 有属性'y'吗?# Truegetattr(obj, 'y') # 获取属性'y'  # 19obj.y # 获取属性'y'# 19getattr(obj,'z')  # 如果试图获取不存在的属性,会抛出AttributeError的错误# AttributeError: 'MyObject' object has no attribute 'z'getattr(obj, 'z', 404) # 获取属性'z',如果不存在,返回默认值404# 404'''也可以获取方法'''hasattr(obj, 'power') # 有方法'power'吗?# Truegetattr(obj, 'power') # 获取方法'power'# 
>fn = getattr(obj, 'power') # 获取方法'power'并赋值到变量fnfn # fn指向obj.power#
>fn() # 调用fn()与调用obj.power()是一样的# 81

类属性和实例属性:实例属性就是上面的self.name之类的携带self,而类属性的定义没有self,并且一般放在初始化函数之前,即开头。

>>> class Student(object):...     name = 'Student'  # 定义一个类属性...s = Student() # 创建实例sprint(s.name) # 打印name属性,因为实例并没有name属性,所以会继续查找class的name属性# Studentprint(Student.name) # 打印类的name属性Students.name = 'Michael' # 给实例绑定name属性,创建实例属性print(s.name) # 由于实例属性优先级比类属性高,因此,它会屏蔽掉类的name属性# Michaelprint(Student.name) # 但是类属性并未消失,用Student.name仍然可以访问Studentdel s.name # 如果删除实例的name属性,删除实例属性print(s.name) # 再次调用s.name,实例属性删除,但是类属性依旧在# Student

内部方法调用类属性的方式建议以下两种:

# 要求:为了统计学生人数,可以给Student类增加一个类属性,每创建一个实例,该属性自动增加class Student(object):    count = 0    def __init__(self, name):        self.name = name        Student.count += 1  # 若使用count会出错,因为count在Student中时局部变量'''方法二'''class Student(object):    count = 0    def __init__(self, name):        self.name = name        self.add_count()  # 采用类方法    @classmethod  # 类方法(不需要实例化类就可以被类本身调用)    def add_count(cls):  # cls : 表示没用被实例化的类本身        cls.count += 1

 

 

 

 

转载地址:https://blog.csdn.net/zz2230633069/article/details/108127197 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:函数的定义的四个注意部分,定义的两种方式及其分号结尾的情况,函数参数的2个关键字(arguments,rest),return正确写法
下一篇:面向对象,即class类,类的封装,属性的类别划分,

发表评论

最新留言

逛到本站,mark一下
[***.202.152.39]2024年04月22日 18时01分16秒