zoukankan      html  css  js  c++  java
  • python中子类继承父类成员变量之间的取值逻辑---自创

    python中子类继承父类成员变量之间的取值逻辑

    代码:

    # 定义父类person
    class person():
    def __init__(self,name,age,sex):
    self.name="zhangxiao"
    self.age='18'
    self.sex=sex
    def talk(self):
    print("i want to speak something to yo!!")
    # 定义子类chinese
    class chinese(person):
    def __init__(self,name,age,sex,language):
    # 先继承父类的构造方法的两种方式 :
    # super(chinese, self).__init__(name,age,sex)#2. 新式类的写法:super(子类,self).__init__(参数1,参数2,....)
    person.__init__(self,name,age,sex)#1.经典类的写法: 父类名称.__init__(self,参数1,参数2,...)
    self.age=age # 定义时:此self为子类的实例,若有此定义则调用sex属性时取的为子类实例化的参数;若未指定则传入的为父类构造方法中写定的参数
    self.language="chinese"
    def talk(self):
    print("我说的是中国话!!")
    c=chinese("xiaoli",'33','nan',"chinese")
    print(c.name)#对应场景A
    print(c.age)#对应场景B
    print(c.sex)#对应场景C
    print(c.talk())
    总结:
    A:若父类中初始化了成员变量,子类调用父类构造方法未覆盖属性(self.sex),则调用子类属性时取值为父类中初始化的成员变量;
    B:若父类中初始化了成员变量,若子类调用父类构造方法覆盖属性(self.sex)则取值为子类实例中传入参数
    C:若父类未初始化该成员变量则,无论子类中有无进行对父类构造方法进行属性的覆盖,均取子类实例中传入的参数
    D:对于方法则子类重写父类方法,调用时直接覆盖父类的方法
  • 相关阅读:
    js/es6判断对象是否为空,并判断对象是否包含某个属性
    Hive中的SQL执行计划--几乎所有的SQL都有
    spark中的scalaAPI之RDDAPI常用操作
    spark-scala开发的第一个程序WordCount
    linux中添加自定义命令
    kafka学习总结
    flume的sink写入hive表
    Flume架构以及应用介绍(转)
    Appache Flume 中文介绍(转)
    hiveSQL常用日期函数
  • 原文地址:https://www.cnblogs.com/lnn123/p/10540944.html
Copyright © 2011-2022 走看看