目录
一、多态
二、各种概念
三、各种方法
四、函数参数
一、多态
什么时候会发生多态:
-
发生继承
-
子类重写父类方法
-
子类重写父类的方法需要被调用(就是被调用的这个时候就叫做多态)
class Dog(object):
def work(self): # 父类提供统一的方法,哪怕是空方法
print('指哪打哪...')
class ArmyDog(Dog): # 继承Dog类
def work(self): # 子类重写父类同名方法
print('追击敌人...')
class DrugDog(Dog):
def work(self):
print('追查毒品...')
class Person(object):
def work_with_dog(self, dog): # 传入不同的对象,执行不同的代码,即不同的work函数
dog.work()
ad = ArmyDog()
dd = DrugDog()
daqiu = Person()
daqiu.work_with_dog(ad)
daqiu.work_with_dog(dd)
二、各种概念
类: 仅仅是一个概念并没有实际的存在
class Province:
# 类属性 存储在类空间中的
country = "中国"
def __init__(self, name):
self.name = name
def show_info(self):
print(self.name)
# 1. henan这个对象只能使用河南这个属性 使用不了河北这个属性
henan = Province("河南")
print(henan.name)
hebei = Province("河北")
print(hebei.name)
# 2. 类也不可以使用对象的属性
# print(Province.name)
# 3. 对象可以使用类属性
print(henan.country)
# 4. 类可以使用类属性的
print(Province.country)
类对象: 存储一些公共的属性和方法的内存空间, 类对象空间
类属性: 所有的对象都具有的属性
-
country就是类属性
实例对象: 通过类创建出来的对象, 并且会有一片独立的空间来存储自己独有的一些属性的一个空间
-
实例对象的空间的特点, 就是只有对象自己可以使用本身的属性
实例属性: 独立属于一个对象的独有属性, 存储在对象空间中的(self)
-
self.name = "河南" 实例属性
实例方法: 就是专门用来修改和使用实例属性的方法(self, 通过self可以获取到对象的空间进而进行使用和修改)
类方法: 就是用来专门修改或者调用类属性的方法(cls, cls可以找到类的空间进而进行修改和调用)
静态方法: 无法修改实例属性也无法修改类属性, (什么参数也没有)
三、各种方法
class Province:
# 类属性 存储在类空间中的
country = "中国"
def __init__(self, name):
self.name = name
# 实例方法, self, 同时可以修改和调用实例属性
def show_info(self):
print(self.name)
# 类方法(语法糖,装饰器)
# cls存储的是类对象空间的地址
@classmethod
def show_country(cls):
cls.country = "china"
print(cls.country)
# 静态方法
# 没有任何特殊参数的, 不会修改类属性和实例属性
@staticmethod
def show():
print("欢迎!!!")
# 5. 实例对象是可以调用类方法的
henan = Province("河南")
henan.show_country()
# 6. 实例对象是可以调用静态方法的
henan.show()
# 7. 类可以调用静态方法
Province.show()
# 8. 类可以使用类方法
Province.show_country()
# 9. 类是没办法直接使用实例方法的(参数的问题)
Province.show_info()
四、函数参数
# 把函数作为参数来使用的一种方式
def func():
print('func')
def my_test(data):
data()
my_test(func)
print(func)
普通变量(引用)
-
a = 10
-
a 存储的是一个空间地址, 这个片空间存储的是10这个数据
-
print(a) 实际上是到 a存放的空间去使用10这个数据
-
-
def func()
-
func 存放的是函数所在的空间的地址
-
func() 去到空间中执行里面的代码
-
函数参数: 把一个函数作为参数给到另一个函数进行使用
<end>