26

今日内容

动静态方法

'''在类中的函数有许多特性'''
class Student:
    school_name = '清华大学'
    # 1.类中直接定义函数 默认绑定给对象 类调用多少参数就传入多少参数 默认读一个参数就是对象本身
    def func(self):
        print('我是第一种情况')
    # 2.被@classmethod修饰的函数 默认绑定给类 类调用第一个参数就是类自身 对象也可以调用并且会自动将产生该对象的类当作第一个参数传入
    @classmethod
    def func2(cls):
        print('我是第二种情况')
        
    # 3.普普通通的函数 无论是类还是对象调用 都必须自己手动的传参
    @staticmethod
    def func3(a):
        print('我是第三种情况')
      
    
obj = Student()
# 1.绑定给对象的方法
obj.func1()
Student.func1(123)
# 2.绑定给类的方法
Student.func2()
obj.func2()
# 3.静态的绑定
Student.func3(123)
obj.func3(123)

面向对象之继承的概念

'''
面向对象三大特征
	封装 继承 多态
1.三者中以继承为核心 (实操最多 体验最强)
2.封装和多态略微抽象
'''

#继承的含义
	在显示生活中继承表示人与人之间资源的从属关系
     	eg:继承家产
    在编程世界中继承表示类与类之间的从属关系
    	eg:类a继承了类b
#继承的目的
	在现实生活中儿子继承父亲所有资源的支配权限
    在编程世界中类A继承类B就拥有了类B中所有的数据和方法使用权限
#继承的实操
	class Son(Father):
        pass
    1.在定义类的时候类名后面可以添加括号填写其他类名 意味着继承其他类
    2.在python支持多继承 括号内填写多个类名彼此逗号隔开就行
    class Son(F1,F2,F3):
        pass
'''
    1.继承其他类的类	Son
    	我们称之为子类、派生类
    2.被继承的类 Father F1 F2 F3
    	我们称之为父类、基类、超类
    ps:最常用的就是子类和父类
'''
    

继承的本质

'''
对象:数据与功能的结合体
类:多个对象相同功能和数据的结合体
父类:多个类(子类)相同的功能和数据的结合体
ps:类与父类目的都是为了节省代码
'''
继承本质应该分为两部分
	 抽象:将多个类相同的东西抽出去形成一个新的类
     继承:将多个类继承刚刚抽出去的新的类

名字的查找顺序

1.不继承名字的查找顺序
	class C1:
    	name = 'a'
        
        def func(self):
            print('from func')
            
    obj = C1()
    print(obj) # 肯定是自己类中的名字
    obj.name = '现在呢'
    print(obj.name) # 现在呢
    print(C1.name)  # a
    '''
    查找顺序
    	1.先从自己的名称空间中查找
    	2.自己没有再去产生该对象的类中查找
    	3.如果类中也没有 直接寄(报错)
    对象自身 >>> 产生对象的类
    '''
2.单继承的情况下名字的查找顺序
	class F1:
        name = 'F1'
    class S1(F1):
        name = 'kevin'
    obj = S1()
    obj.name = 'oscar'
    print(obj.name)
    'oscar'>>>'kevin'>>>'F1'
'''
对象本身 >>> 对象所在的类 >>> 父类
'''
#试着说出下面的结果:
    class F1():
        name = 'xiaochen'
        pass
    class F2(F1):
        name = 'tony'
        pass
    class F3(F2):
        name = 'osicar'
        pass
    class S1(F3):
        name = 'kevin'
        
#变形
	class A1:
        def func1(self):
            print('from A1 func1')
            
        def func2(self):
            print('from A1 func2')
            self.func1()
            
     class B1(A1):
        def func1(self):
            print('from B1 func1')
            
    obj = B1()
    obj.func2()
    '''
    强调:对象点名字 永远从对象自身开始一步步查找
    以后在看到self.名字的时候 一定要搞清楚self是指哪一个对象
    '''

image

#3.多继承情况下名字查找顺序
	菱形继承
    	广度优先(最后再闭环的定点)

image

	非菱形继承
    	深度优先
'''
查找的顺序:
对象 >>> 对象所在的类 >>> 父类(从左到右) 
'''
# 使用对象点mro()可以查看名字查找的顺序哦

image

经典类与新式类

"""
经典类:不继承object或者其子类的类
新式类:继承object或者其子类的类
    在python2中有经典类和新式类
    在python3中只有新式类(所有类默认都继承object)
"""
class Student(object):pass
ps:以后我们在定义类的时候 如果没有其他明确的父类 也可能习惯写object兼容

派生方法

'''继承的基础上 往类中加上一些特点的属性 这样类不仅具有父类的属性 还有自己的属性'''
#代码实现:
class Person():
    def __init__(self,name,age):
        self.name = name
        self.age = age
        
假设我们现在有个新的需求 在姓名和年龄的基础上再添加数据
class Student(Person):
    def __init__(self,name,age,sid):
        #添加一个sid的数据
        super().__init__(name,age)   # 子类调用父类的方法
        self.sid = sid
        #super的完整写法 super(Student,self) 但在python3中帮我们写好了 我们可以简写
        
这样再后续创建对象照样传参就行
stu1 = Student('jason',18,666)

派生方法的特别使用

list 在python也是一个类 可以点出许多方法 比如 append
假设我们想要尾部追加 但不能追加一些指定的数据
代码实现:
	class Mylist(list):
        def append(self,values):
            if values == 'aaa':
                print('aaa无法进行尾部追加')
                return
            super().append(values)
            
     obj = Mylist()
    obj.append(111)
    obj.append(222)
    obj.append('aaa') 
    

image

posted @ 2022-11-03 19:24  早点早点灬  阅读(90)  评论(0)    收藏  举报