面向对象(部分讲解)
动静态方法
绑定给对象的方法
直接在类体代码中编写即可,对象调用会自动将对象当作第一个参数传入
class Student:
school = '清华大学'
def __init__(self,name):
self.name = name
def run(self): # self用于接受对象
print(f'{self.name}快跑!') # jason快跑!
s1 = Student('jason')
s1.run()
绑定给类的方法
无论是类还是类实例化产生的对象来调用,默认传入的参数都为类
class Student:
school = '清华大学'
def __init__(self,name):
self.name = name
@classmethod # 绑定给类的方法
def run(cls): # cls用来接受类
print(f'类{cls}来调用的函数')
p1 = Student('jason')
p1.run() # 类<class '__main__.Student'>来调用的函数
Student.run() # 类<class '__main__.Student'>来调用的函数
静态方法
类和对象都可以调用,但无论谁来调用都必须按照判断的传参方式
class Student:
school = '清华大学'
def __init__(self,name):
self.name = name
@staticmethod # 静态方法
def sleep(a,b): # 无论谁来调用都必须正常传参
print('静态方法')
继承的概念
面向对象的三大特性分别是:封装、继承、多态
继承的定义
1.继承的含义
在现实生活中继承就是用来描述人与人之间资源的从属关系
eg:儿子继承父亲的财产(拥有了父亲所有的资源)
在编程的世界里继承其实就是用来描述类与类之间的数据关系
eg:类A继承类B(拥有了类B里面所有的数据和功能)
2.继承的目的
在现实生活中儿子继承父亲就拥有了父亲所有资源的支配权限
在编程世界中类A继承类B就拥有了类B中所有的数据和方法使用权限
3.继承的实操
class 类名(父类名):
pass
1.定义类的时候在类名后加括号
2.括号内填写你需要继承的类名
3.括号没可以填写多个父类,逗号隔开即可
"""
我们将被继承的类称之为:父类 或 基类 或 超类
我们将继承类的类称之为:子类 或 派生类
而我们平时最常用的就是父类和子类
"""
继承的本质
抽象:将多个类共同的数据和功能抽取出来形成一个基类
继承:从上往下白嫖各个基类里面的资源
对象: 数据与功能的结合体
类: 多个对象相同的数据和功能的结合体
父类:多个类相同的数据和功能的结合体
为什么要使用继承
1.减少重复的代码,简化代码
2.提高代码的维护性
3.提高代码的复用性
名字的查找顺序
不继承的情况
先从对象自身查找,没有的话,再去产生对象的类中查找
class Student:
school = '清华大学'
def choice_course(self):
print('正在选课')
s1 = Student()
print(s1.school) # 清华大学 对象查找school,自身名称空间没有,所以查找的是类的school
s1.school = '北京大学' # 在自身的名称空间产生了新的school
'对象点名字并写了赋值符号和数据值,那么操作的肯定是自己的名称空间'
print(s1.school) # 北京大学
print(Student.school) # 清华大学
查找顺序: 对象 >>> 类
单继承的情况
先从对象自身查找,然后产生该对象的类,然后是一个个父类
class F1:
name = 'from F1'
class F2:
name = 'from F2'
class F3:
name = 'from F3'
class MyClass(F1,F2,F3):
name = 'from MyClass'
obj = MyClass()
print(obj.name)
对象 >>> 类 >>> 父类...
class A1:
def func1(self):
print('from A1 func1')
def func2(self):
print('from A1 func2')
self.func1()
def func3(self):
print('from A1 func3')
class MyClass(A1):
def func1(self):
print('from MyClass func1')
obj = MyClass()
obj.func2()
'''只要涉及到对象查找名字,就要回到最开始的位置依次查找'''
"""
输出结果:
from A1 func2
from MyClass func1
"""
多继承情况
菱形继承
广度优先(最后才会找闭环的定点)

非菱形继承
深度优先(从左往右每条道走完为止)

经典类与新式类
经典类:不继承object或其子类的类(什么都不继承)
新式类:继承了object或其子类的类
- 在python3中所有的类默认都会继承object,也就意味着python3里面只有新式类
- 在python2中有经典类和新式类,由于经典类没有核心的功能,所以到了python3直接砍掉了
以后我们在定义类的时候,如果没有想要继承的父类,一般推荐:
class MyClass(object):
pass
'目的是兼容python2'
派生方法
子类中定义类与父类一模一样的方法并且扩展了该功能
class MyList(list):
def append(self,obj):
if obj =='jason':
raise Exception('jason不能被添加到列表中')
super().append(obj)
a = MyList()
a.append(11)
a.append(22)
print(a)
a.append('jason')
'派生可以让我们不仅拥有list类的所有功能,同时,我们还可以对某些功能进行过滤扩展。'


浙公网安备 33010602011771号