二十二. Python基础(22)--继承

● 知识框架

 

● 继承关系中self的指向

当一个对象调用一个方法时,这个方法的self形参会指向这个对象

class A:

    def get(self):

        self.say()

 

    def say(self):

        print('AAAAA')

 

class B(A):

    def say(self):

        print('BBBBB')

 

b = B()

b.get() # BBBBB

# 当一个对象调用一个方法时,这个方法中的self就指向这个对象

# 子类先调用自己的属性或方法, 子类自己没有才调父类的

# 如果是class B(A):pass, 那么结果是'AAAAA'

print(dir(b))

# ['__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'cls_att', 'get', 'name', 'say']

print(b.__dict__)

# {'name': 'Arroz'}

print(vars(b))

# {'name': 'Arroz'}

print(b.__class__)

# <class '__main__.B'>

print(B.__class__)

#<class 'type'> # 实例关系

print(B.__bases__)

# (<class '__main__.A'>,) # 继承关系

print(B.__doc__)

# This is class B

 

● 经典类(old-style)和新式(new-style)类调用父类方法的区别

class Dog(Animal):

    def __init__(self, name):

        # Animal.__init__(self, name) # 经典类, 注意不要遗漏self

        super().__init__(name) # 新式类, 等价于super(Dog, self).__init__(name),读作"调用Dog的父类

         的方法(calling Dog's parent's method)"

内置函数super([type[, object-or-type]])

Return a proxy object that delegates method calls to a parent or sibling class of type. This is useful for accessing inherited methods that have been overridden in a class. The search order is same as that used by getattr() except that the type itself is skipped.

 

● 综合案例

class Base:

    cls_attr = 'class attribute'

    def __init__(self, name, age, job):

        self.name = name

        self.age = age

        self.job = job

    def bmeth(self):

        print('Base method')

 

class Derived_0(Base):

    def dmeth(self):

        print('Derived method')

 

print(type(Base)) # <class 'type'>, 元类

print(type(Derived_0)) # <class 'type'>, 元类

 

# 没有添加新的对象属性, 不用使用super()

d_0 = Derived_0('Paul', 55, 'Singer')

print(d_0.job)

 

# 下面添加了添加了新的对象属性, 需要使用super()

class Derived_1(Base):

    def __init__(self, name, age, job, hobby):

        super(Derived_1, self).__init__(name, age,job) #
子类调用父类方法时, 参数的个数不能缺少.

        self.hobby = hobby

    def dmeth(self):

        print('Derived method')

    def show(self):

        print(self.name, self.age, self.job,self.hobby)

 

class Derived_2(Base):

    def __init__(self, name, hobby):

        super(Derived_2, self).__init__(name, 20, 'teacher') # 子类调用父类方法时, 参数的个数不能缺少, 并且可以把已知的属性先传给父类的构造函数

        self.hobby = hobby

    def dmeth(self):

        print('Derived method')

    def show(self):

        print(self.name, self.age, self.job,self.hobby)

 

class Derived_3(Base):

    def __init__(self, hobby):

        super(Derived_3, self).__init__("Paul", 22, 'painter') # 子类调用父类方法时, 参数的个数不能缺少, 并且可以把已知的属性先传给父类的构造函数

        self.hobby = hobby

 

    def dmeth(self):

        print('Derived method')

 

    def show(self):

        print(self.name, self.age, self.job, self.hobby)

 

#① #######################################################

b = Base('Arroz', 18, 'teacher')

print(Base.__dict__) # 类的属性

'''

{'__module__': '__main__', 'cls_attr': 'class attribute', '__init__': <function Base.__init__ at 0x00000000028EA840>, 'bmeth': <function Base.bmeth at 0x00000000028EA8C8>,

'__dict__': <attribute '__dict__' of 'Base' objects>, '__weakref__': <attribute '__weakref__' of 'Base' objects>, '__doc__': None}

'''

print(b.__dict__) # 对象属性

'''

{'name': 'Arroz', 'age': 18, 'job': 'teacher'}

'''

print('----------------------')

#② #######################################################

d_1 = Derived_1('Arroz', 18, 'teacher','swimming')

d_1.show() # Arroz 18 teacher swimming

print('----------------------')

#③ #######################################################

d_2 = Derived_2('Pwter', 'skating')

d_2.show() # Pwter 20 teacher skating

print('----------------------')

#④ #######################################################

d_3 = Derived_3('jogging')

d_3.show() # Paul 22 painter jogging

 

二十二. Python基础(22)--继承的更多相关文章

  1. 二十四. Python基础(24)--封装

    二十四. Python基础(24)--封装 ● 知识结构   ● 类属性和__slots__属性 class Student(object):     grade = 3 # 也可以写在__slots ...

  2. 二十六. Python基础(26)--类的内置特殊属性和方法

    二十六. Python基础(26)--类的内置特殊属性和方法 ● 知识框架 ● 类的内置方法/魔法方法案例1: 单例设计模式 # 类的魔法方法 # 案例1: 单例设计模式 class Teacher: ...

  3. 二十五. Python基础(25)--模块和包

    二十五. Python基础(25)--模块和包 ● 知识框架   ● 模块的属性__name__ # my_module.py   def fun1():     print("Hello& ...

  4. JAVA基础知识总结:一到二十二全部总结

    >一: 一.软件开发的常识 1.什么是软件? 一系列按照特定顺序组织起来的计算机数据或者指令 常见的软件: 系统软件:Windows\Mac OS \Linux 应用软件:QQ,一系列的播放器( ...

  5. python3.4学习笔记(二十四) Python pycharm window安装redis MySQL-python相关方法

    python3.4学习笔记(二十四) Python pycharm window安装redis MySQL-python相关方法window安装redis,下载Redis的压缩包https://git ...

  6. Bootstrap <基础二十二>超大屏幕(Jumbotron)

    Bootstrap 支持的另一个特性,超大屏幕(Jumbotron).顾名思义该组件可以增加标题的大小,并为登陆页面内容添加更多的外边距(margin).使用超大屏幕(Jumbotron)的步骤如下: ...

  7. python3.4学习笔记(二十六) Python 输出json到文件,让json.dumps输出中文 实例代码

    python3.4学习笔记(二十六) Python 输出json到文件,让json.dumps输出中文 实例代码 python的json.dumps方法默认会输出成这种格式"\u535a\u ...

  8. python3.4学习笔记(二十五) Python 调用mysql redis实例代码

    python3.4学习笔记(二十五) Python 调用mysql redis实例代码 #coding: utf-8 __author__ = 'zdz8207' #python2.7 import ...

  9. python3.4学习笔记(二十二) python 在字符串里面插入指定分割符,将list中的字符转为数字

    python3.4学习笔记(二十二) python 在字符串里面插入指定分割符,将list中的字符转为数字在字符串里面插入指定分割符的方法,先把字符串变成list然后用join方法变成字符串str=' ...

随机推荐

  1. Qt 快捷键 复制当前行 向上复制 && 向下复制

    网上的答案不一,我的快捷键是默认的配置,未做过修改. 向前复制当前行: Ctrl + Alt + up (向上箭头) 向后复制当前行:Ctrl + Alt + down(向下箭头) 补充一个:Ctrl ...

  2. hive sql执行的job在map时报java.lang.OutOfMemoryError的错误

    较为详细且重要的一段报错信息是org.apache.hadoop.mapred.YarnChild: Error running child : java.lang.OutOfMemoryError: ...

  3. caffe-ssd编译runtest时候报错:g++: internal compiler error: Killed (program cc1plus)

    大哥,你的内存不够了,删点儿东西吧

  4. tensorflow输出

    在Session对象上调用run()函数,执行流图,即可得到输出, 可获取单个输出,也可获取多个输出 import tensorflow as tf import numpy as np consta ...

  5. JavaScript 原型链学习(二)原型的动态性

    由于在原型中查找值的过程是一次搜索,因此我们对原型对象所做的任何修改都能够立即从实例上反映出来,即使是先创建了实例后修改原型也照样如此.如下示例: var friend = new Person(); ...

  6. vuejs服务端渲染更好的SEO,SSR完全指南Nuxt.js静态站生成器

    vuejs服务端渲染更好的SEO,SSR完全指南Nuxt.js静态站生成器SSR 完全指南https://cn.vuejs.org/v2/guide/ssr.html在 2.3 发布后我们发布了一份完 ...

  7. flutter stack

    import 'package:flutter/material.dart'; void main() { runApp(MaterialApp(home: new MyApp())); } clas ...

  8. ORA-12805: parallel query server died unexpectedly ORA-04030 (sort subheap,sort key) 原因排查与解决方法

    今日,某服务器pga调整为30G,_pga_max_size调整为8G之后(原来是2G,但是one passes语句较多,性能太低),执行出现ORA-12805: parallel query ser ...

  9. Java基础学习-HelloWorld案例的编写和运行

    一.HelloWorld案例的流程:         第一步:编写一个.java的源文件.通过Windows自带的记事本文件就可以完成.         第二步:将.java的源文件通过编译器编译生成 ...

  10. SELinux/SEAndroid 实例简述(二) TE语言规则【转】

    本文转载自:https://blog.csdn.net/shell812/article/details/54930246 版权声明:本文为博主原创文章,未经博主允许不得转载.    https:// ...