面向对象篇(六)
多态
多态指的是一类事物有多种形态,一个抽象类有多个子类(因而多态的概念依赖于继承),不同的子类对象调用相同的方法,产生不同的执行结果,多态可以增加代码的灵活度
实现多态的步骤:
1、定义一个父类(Base),实现某个方法(比如:run)
2、定义多个子类,在子类中重写父类的方法(run),每个子类run方法实现不同的功能
3、假设我们定义了一个函数,需要一个Base类型的对象的参数,那么调用函数的时候,传入Base类不同的子类对象,那么这个函数就会执行不同的功能,这就是多态的体现。
一个父类,他具有多个子类,不同的子类在调用相同的方法,执行的时候产生不同的形态,这个叫多态
class Animal(object):"""动物类"""def func(self):print('动物发出了声音')class Cat(Animal):"""猫类"""def func(self):print('喵 喵 喵')class Dog(Animal):"""狗类"""def func(self):print('汪 汪 汪 ')class Hero:def func(self):print('这个是英雄类的方法,不是动物类的对象')def work01(musen: Animal):musen.func()work01(Hero())
以下是实例输出的效果:
类属性与方法
类的私有属性
__private_attrs:两个下划线开头,声明该属性为私有,不能在类的外部被使用或直接访问。在类内部的方法中使用时 self.__private_attrs。
类的私有属性实例如下:
class JustCounter:__secretCount = 0 # 私有变量publicCount = 0 # 公开变量def count(self):self.__secretCount += 1self.publicCount += 1print (self.__secretCount)counter = JustCounter()
counter.count()
counter.count()
print (counter.publicCount)
print (counter.__secretCount) # 报错,实例不能访问私有变量
执行以上程序输出结果为:
类的方法
在类的内部,使用 def 关键字来定义一个方法,与一般函数定义不同,类方法必须包含参数 self,且为第一个参数,self 代表的是类的实例。
self 的名字并不是规定死的,也可以使用 this,但是最好还是按照约定使用 self。
#类定义
class people:#定义基本属性name = ''age = 0#定义私有属性,私有属性在类外部无法直接进行访问__weight = 0#定义构造方法def __init__(self,n,a,w):self.name = nself.age = aself.__weight = wdef speak(self):print("%s 说: 我 %d 岁。" %(self.name,self.age))# 实例化类
p = people('runoob',10,30)
p.speak()
执行以上程序输出结果为:
类的私有方法
__private_method:两个下划线开头,声明该方法为私有方法,只能在类的内部调用 ,不能在类的外部调用。self.__private_methods。
类的私有方法实例如下:
class Site:def __init__(self, name, url):self.name = name # publicself.__url = url # privatedef who(self):print('name : ', self.name)print('url : ', self.__url)def __foo(self): # 私有方法print('这是私有方法')def foo(self): # 公共方法print('这是公共方法')self.__foo()x = Site('博客', 'www.qianfu.com')
x.who() # 正常输出
x.foo() # 正常输出
x.__foo() # 报错
以上实例执行结果:
类方法
类方法以cls作为第一个参数,cls表示类本身,定义时使用@classmethod装饰器。通过cls可以访问类的相关属性
class person(object):tall = 180hobbies = []def __init__(self, name, age,weight):self.name = nameself.age = ageself.weight = weight@classmethod # 类的装饰器def infoma(cls): # cls表示类本身,使用类参数clsprint(cls.__name__)print(dir(cls))
# 1. 直接调用类的装饰器函数,通过cls可以访问类的相关属性
person.infoma()
# 2. 通过两步骤来实现,第一步实例化person,第二步调用装饰器
# Bruce = person("Bruce", 25,180)
# Bruce.infoma()
以上实例执行结果:
静态方法
与实例方法和类方法不同,静态方法没有参数限制,既不需要实例参数,也不需要类参数,定义的时候使用@staticmethod装饰器。同类方法一样,静态法可以通过类名访问,也可以通过实例访问。
class person(object):tall = 180hobbies = []def __init__(self, name, age,weight):self.name = nameself.age = ageself.weight = weight@staticmethod # 静态方法装饰器def infoma(): # 没有参数限制,既不要实例参数,也不用类参数print(person.tall)print(person.hobbies)
# 1. 通过类名访问
#person.infoma()
# 2. 通过实例访问
Bruce = person("Bruce", 25,180)
Bruce.infoma()
以上实例执行结果: