day23

初识继承

字面意思:儿子可以完全使用父亲的所有内容

专业角度:如果B类继承A类,

B类就称为子类、派生类

A类就称为父类、基类、超类

面向对象三大特性:继承、封装、多态

继承:单继承、多继承

# class Human:
# def __init__(self, name, sex, age):
# self.name = name
# self.age = age
# self.sex = sex
#
#
# class Dog:
# def __init__(self, name, sex, age):
# self.name = name
# self.age = age
# self.sex = sex
#
#
# class Cat:
# def __init__(self, name, sex, age):
# self.name = name
# self.age = age
# self.sex = sex
继承
class Animal:
def __init__(self, name, sex, age):
self.name = name
self.age = age
self.sex = sex class Human(Animal):
pass class Dog(Animal):
pass class Cat(Animal):
pass # Human,Dog,Cat 子类、派生类
# Animal 父类、基类、超类
person = Human("李业", "男", 18)
print(person.name)

继承的优点

  • 减少了重复代码
  • 增加了类的耦合性(耦合性不宜多,宜精)
  • 使得代码更加规范化,合理化

单继承

  • 类名执行父类属性方法
class Animal:
live = "有生命的" def __init__(self, name, sex, age):
self.name = name
self.age = age
self.sex = sex def eat(self):
print("动物都需要进食") class Human(Animal):
live = "有思想的活着" # 1、类名执行父类属性方法
print(Human.live)
Human.eat(111)
  • 对象执行父类属性方法

    查询顺序单向不可逆: 子类使用父类的属性方法,父类不能使用子类的属性方法.

class Animal:
live = "有生命的" def __init__(self, name, sex, age):
self.name = name
self.age = age
self.sex = sex def eat(self):
print(self)
print("动物都需要进食") class Human(Animal):
body = "有头有脸" # 2、子类对象执行父类的属性方法
obj = Human('汪洋', '男', 48)
print(obj.live)
obj.eat()
print(obj)
# a1 = Animal('汪洋', '男', 48)
# print(a1.body) # 报错,父类不能获取子类属性
  • 在子类中既执行子类方法又执行父类方法

方法一:不依赖继承的

# class Animal:
# def __init__(self, name, sex, age):
# self.name = name
# self.age = age
# self.sex = sex
#
#
# class Human:
# def __init__(self,name, sex, age, hobby):
# '''
#
# :param name: 李业
# :param sex: 男
# :param age: 18
# :param hobby: 旅游
# '''
# # self = obj
# # Animal.__init__(人类对象,姓名,性别,年龄)
# Animal.__init__(self,name,sex,age)
# self.hobby = hobby
#
#
# class Dog(Animal):
# pass
#
#
# class Cat(Animal):
# pass # obj = Human('驴友')
# obj2 = Human('抽烟')
# print(obj.__dict__)
# obj = Human('李业','男',18,'旅游')
# print(obj.__dict__)
# def func(self):
# self = 666
# print(self)
#
# self = 3
# # func(self)
# func(666) # def func1(a,b):
# print(a,b)
#
#
# def func2(argv1,argv2,x):
# func1(argv1,argv2)
# print(x)
#
# func2(1,2,666)

方法二: 依赖于继承

class Animal:

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

        self.name = name
self.age = age
self.sex = sex def eat(self):
print('动物都需要吃饭') class Human(Animal): def __init__(self, name, sex, age, hobby): # Animal.__init__(self,name,sex,age)
# super(Human,self).__init__(name, sex, age) #完整的写法
super().__init__(name,sex,age) # 执行父类的__init__方法,重构父类方法.
self.hobby = hobby def eat(self):
print(f'{self.name}都需要吃饭') # class Dog(Animal):
# pass
#
#
# class Cat(Animal):
# pass
#
obj = Human('李业','男',18,'旅游')
obj.eat()
# print(obj.__dict__)
单继承练习题
# 1
class Base:
def __init__(self, num):
self.num = num
def func1(self):
print(self.num) class Foo(Base):
pass
obj = Foo(123)
obj.func1()
# 123 # 2
class Base:
def __init__(self, num):
self.num = num
def func1(self):
print(self.num)
class Foo(Base):
def func1(self):
print("Foo. func1", self.num)
obj = Foo(123)
obj.func1()
# Foo.func1 123 # 4
class Base:
def __init__(self, num):
self.num = num
def func1(self):
print(self.num)
self.func2()
def func2(self):
print("Base.func2")
class Foo(Base):
def func2(self):
print("Foo.func2")
obj = Foo(123)
obj.func1()
# 123
# Foo.func2 # 再来
class Base:
def __init__(self, num):
self.num = num
def func1(self):
print(self.num)
self.func2()
def func2(self):
print(111, self.num)
class Foo(Base):
def func2(self):
print(222, self.num)
lst = [Base(1), Base(2), Foo(3)]
for obj in lst:
obj.func2()
# 111 1
# 111 2
# 222 3 # 再来
class Base:
def __init__(self, num):
self.num = num
def func1(self):
print(self.num)
self.func2()
def func2(self):
print(111, self.num)
class Foo(Base):
def func2(self):
print(222, self.num)
lst = [Base(1), Base(2), Foo(3)]
for obj in lst:
obj.func1()
# 1
# 111 1
# 2
# 111 2
# 3
# 222 3

多继承

引导
class ShenXian:
def fly(self):
print("神仙都会飞") def walk(self):
print("神仙都会走路") class Monkey:
def climb(self):
print("猴子都会爬树") def walk(self):
print("猴子会走路") class SunWuKong(ShenXian, Monkey):
pass sun = SunWuKong()
sun.fly()
sun.climb()
sun.walk()

python 类分为两种:

python2x:

python2.2之前,都是经典类

python2.2之后,经典类与新式类共存

python3x:

全部都是新式类

经典类

不继承object类,深度优先原则

深度优先原则:从左至右,深度优先

新式类

继承object类,mro(C3)算法

mro算法

class O:
pass class D(O):
pass class E(O):
pass class F(O):
pass class B(D,E):
pass class C(E,F):
pass class A(B,C):
pass obj = A()
print(obj.name) # mro(Child(Base1,Base2)) = [ Child ] + merge( mro(Base1), mro(Base2), [ Base1, Base2] )
# mro(A(B,C)) = [A] + merge(mro(B),mro(C),[B,C]) """
mro(A(B,C)) = [A] + merge(mro(B),mro(C),[B,C]) mro(B) = mro(B(D,E)) = [B] + merge(mro(D),mro(E),[D,E])
mro(B) = mro(B(D,E)) = [B] + merge([D,O],[E,O],[D,E])
mro(B) = mro(B(D,E)) = [B,D] + merge([O],[E,O],[E])
mro(B) = mro(B(D,E)) = [B,D,E] + merge([O],[O])
mro(B) = mro(B(D,E)) = [B,D,E,O] mro(C) = mro(C(E,F)) = [C] + merge(mro(E),mro(F),[E,F])
mro(C) = mro(C(E,F)) = [C] + merge([E,O],[F,O],[E,F])
mro(C) = mro(C(E,F)) = [C,E] + merge([O],[F,O],[F])
mro(C) = mro(C(E,F)) = [C,E,F] + merge([O],[O])
mro(C) = mro(C(E,F)) = [C,E,F,O] mro(A(B,C)) = [A] + merge([B,D,E,O],[C,E,F,O],[B,C])
mro(A(B,C)) = [A,B] + merge([D,E,O],[C,E,F,O],[C])
mro(A(B,C)) = [A,B,D] + merge([E,O],[C,E,F,O],[C])
mro(A(B,C)) = [A,B,D,C] + merge([E,O],[E,F,O])
mro(A(B,C)) = [A,B,D,C,E] + merge([O],[F,O])
mro(A(B,C)) = [A,B,D,C,E,F] + merge([O],[O])
mro(A(B,C)) = [A,B,D,C,E,F,O]
""" print(A.mro())
# [<class '__main__.A'>, <class '__main__.B'>, <class '__main__.D'>, <class '__main__.C'>, <class '__main__.E'>, <class '__main__.F'>, <class '__main__.O'>, <class 'object'>]

day23——继承的更多相关文章

  1. python学习之旅

    python学习分类 python基础    +- day01——python初始.变量.常量.注释.基础数据类型.输入.if day02——while.字符串格式化.运算符.编码初识 day03—— ...

  2. day23.面向对象之继承

    1.什么是继承 继承是一种创建新类的方式,在python中,新建的类可以继承一个或多个父类,父类又可称为基类或超类,新建的类称为派生类或子类 python中类的继承分为:单继承和多继承 class A ...

  3. python学习 day23 面向对象三大特性之继承

    ### 面向对象三大特性值继承#### 1.什么是继承 继承是一种关系,必须存在两个对象才可能产生这种关系,在现实生活中的继承,王思聪可以继承王健林的财产 被继承的成为父,继承的一方成为子 在程序中, ...

  4. day23:单继承&多继承&菱形继承&__init__魔术方法

    1.单继承 1.1 关于继承的一些基本概念 1.2 子类可以调用父类的公有成员 1.3 子类无法调用父类的私有成员 1.4 子类可以改写父类的方法 2.多继承 2.1 多继承的基本语法 2.2 sup ...

  5. python_way ,day23 API

    python_way ,day23 1.api认证  .api加密动态请求 2.自定义session 一.api认证 首先提供api的公司,如支付宝,微信,都会给你一个用户id,然后还会让你下一个SD ...

  6. day23 框架之基础加强

    day23 框架之基础加强 今日任务 aptana(javascript的eclipse插件):http://www.cnblogs.com/terrylin/archive/2012/06/20/2 ...

  7. day23 02 组合(继续人狗大战游戏)

    day23 02 组合(继续人狗大战游戏) 面向对象的三大特性:继承 多态 封装 先讲解一下组合 组合:一个对象的属性值是另一个类的对象:对象.属性.属性(一般有两个点) 继续扩展day22 01里面 ...

  8. javaScript的原型继承与多态性

    1.prototype 我们可以简单的把prototype看做是一个模版,新创建的自定义对象都是这个模版(prototype)的一个拷贝 (实际上不是拷贝而是链接,只不过这种链接是不可见,给人们的感觉 ...

  9. JavaScript的继承实现方式

    1.使用call或apply方法,将父对象的构造函数绑定在子对象上 function A(){ this.name = 'json'; } function B(){ A.call(this); } ...

随机推荐

  1. 如何使用Microsoft的驱动程序验证程序解释无法分析的崩溃转储文件

    这篇文章解释了如何使用驱动程序验证工具来分析崩溃转储文件. 使用Microsoft驱动程序验证工具 如果您曾经使用Windows的调试工具来分析崩溃转储,那么毫无疑问,您已经使用WinDbg打开了一个 ...

  2. Python 检查代码占用内存 工具和模块

    只介绍简单的使用, 更多使用方法请查看官方文档 tracemalloc 官方文档 tracemalloc文档地址 使用 import tracemalloc tracemalloc.start() # ...

  3. BZOJ 1802: [Ahoi2009]checker

    题目描述 若有两个红格相邻 第一问的答案为0,所有位置上的棋子都可以通过在这两个格子上放棋子得到 第二设f[i]表示想让第i个格子上有棋子需要放的棋子数 若没有,第一问答案为偶数格子上白格的个数,第二 ...

  4. python 项目实战之装饰器

    import logging def use_logging(func): def writelog(*args, **kwargs): logging.warning("%s is run ...

  5. easyui datagrid生成序号列formatter

    var opts1; $('#datagrid_1').datagrid({ columns: [ [{ field: 'myNo', title: '序号', align: 'center', wi ...

  6. pytorch 中conv1d操作

    参考:https://blog.csdn.net/liujh845633242/article/details/102668515 这里我重点说一下1D卷积,2D卷积很好理解,但是1D卷积就不是那么好 ...

  7. abd shell的相关命令

    http://adbshell.com/commands/adb-shell-pwd adb shell pwd adb shell rm -rf /sdcard/DCIM/

  8. Java的面向对象的原则

    1.单一职责原则: /* * (有且只有一个引起功能变化的原因) * 如果在一个类中,承载的功能越多. * 交融的耦合性越高,被复用的可能性越低. * 耦合性高的话,当一个类的职责发生变化的时候,会引 ...

  9. 使用gevent包实现concurrent.futures.executor 相同的公有方法。组成鸭子类

    类名不同,但公有方法的名字和提供的基本功能大致相同,但两个类没有共同继承的祖先或者抽象类 接口来规定他,叫鸭子类. 使并发核心池能够在 threadpoolexetor和geventpoolexecu ...

  10. python自动化接口测试

    前几天,同组妹子说想要对接口那些异常值进行测试,能否有自动化测试的方法.仔细想了一下,工具还挺多,大概分析了一下: 1.soapui:可以对接口参数进行异常值参数化,可以加断言,一般我们会加httpc ...