本文共 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 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!