首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Python菱形继承的初始化问题和继承顺序

Python中,类通过继承的方式,子类可以获得父类的非私有属性和非私有方法,不需要自己再重新实现。 继承可以多层继承,即可以多代继承。也可以多继承,即一个子类可以继承多个父类。...参考:Python中类的继承、多层继承和多继承 ? 一、菱形继承简介 在多层继承和多继承同时使用的情况下,就会出现复杂的继承关系,多重多继承。 其中,就会出现菱形继承,菱形继承也叫钻石继承。...注意:在继承时,如果小括号()中先写Computer再写Phone,则两个类的继承顺序就会调换。 由此,我们可以得出菱形继承的继承顺序了。如下图所示。 ?...五、__mro__方法查看继承顺序 根据上面的案例,我们已经知道了菱形继承中的继承顺序了。 这种继承顺序是遵循广度优先算法的。...也就是说,多层多继承时,先在父级中按先后顺序查找,然后再到父级的父级中查找。 这样,继承顺序已经很清晰了,不过,这还需要我们人工来识别继承顺序。

1.2K20

【java基础☞初始化顺序】java继承中的初始化顺序

1、初始化顺序:父类的静态变量-->父类的静态代码块-->子类的静态变量-->子类的静态代码快-->父类的非静态变量(父类的非静态代码块)-->父类的构造函数-->子类的非静态变量(子类的非静态代码块...初始化 初始化阶段是类加载过程的最后一步,主要是根据程序中的赋值语句主动为类变量赋值。 当有继承关系时,先初始化父类再初始化子类,所以创建一个子类时其实内存中存在两个对象实例。...注:如果类的继承关系过长,单从类初始化角度考虑,这种设计不太可取。原因我想你已经猜到了。 通常建议的类继承关系最多不超过三层,即父-子-孙。...所以Singleton2结果是6和4。 以上除了搞清楚执行顺序外,还有一个重点->结论2:静态资源在类的初始化中只会执行一次。不要与第3个步骤混淆。...按照顺序先是private static Singleton singleton = new Singleton(),根据 结论1 和结论2,value1和value2不会在此层执行赋值操作。

1K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    类、变量、块、构造器、继承初始化顺序,终极解答。

    最近发现微信群里面有些群友在讨论类的初始化顺序,如类的静态变量、成员变量、静态代码块、非静态代码块、构造器,及继承父类时,它们的初始化顺序都是怎样的,下面我通过例子来说明这个情况,以免被人误导。...示例1:测试单类的初始化顺序 public class ClassInitOrderTest { public static String staticField = "static field...block member field non-static block constructor 可以得出以下结论: 静态变量 > 静态初始块 > 成员变量 > 非静态初始块 > 构造器 示例2:测试类继承的初始化顺序...> 父类静态初始块 > 子类静态变量 > 子类静态初始块 > 父类成员变量 > 父类非静态初始块 > 父类构造器 > 子类成员变量 > 子类非静态初始块 > 子类构造器 示例3:测试成员变量、初始块的初始化顺序...} } 程序输出: static field A static block static field B 可以得出以下结论: 静态变量A > 静态初始块 > 静态变量B 所以,它们的在类中的顺序就决定了它们的初始化顺序

    72040

    Java初始化顺序

    Test默认构造函数被调用 -----构造函数执行 由此可以得出结论: a 静态成员变量首先初始化(注意,Static可以看做一个静态成员,其执行顺序和其在类中申明的顺序有关) b 普通成员初始化...对于静态成员(static块可以看成普通的一个静态成员,其并不一定在类初始化时首先执行)和普通成员,其初始化顺序只与其在类定义中的顺序有关,和其他因素无关。...子类 sam1成员初始化 子类 sam2成员初始化 子类 TestSub 默认构造函数被调用 -------父类普通成员初始化和构造函数执行 由此得出Java初始化顺序结论: 1 继承体系的所有静态成员初始化...有的朋友问到内部的机制,上述的初始化顺序是由下面的几条规则决定的: 1.首先初始化静态域是因为静态域是放在方法区和class对象在一起的。...3.另外一条规则是初始化块和域的初始化按照声明的顺序进行。 详见thinking in java中译本第四版的P147页。

    61970

    JAVA初始化顺序

    在一个类里,初始化的顺序是由变量在类内的定义顺序决定的。即使变量定义大量遍布于方法定义的中间, 那些变量仍会在调用任何方法之前得到初始化——甚至在构建器调用之前。...Shows that construction is done } } ///:~ 在Card 中,Tag 对象的定义故意到处散布,以证明它们全都会在构建器进入或者发生其他任何事情之前得到 初始化...除此之外,t3 在构建器内部得到了重新初始化。...它的输入结果如下: Tag(1) Tag(2) Tag(3) Card() Tag(33) f() 因此,t3 句柄会被初始化两次,一次在构建器调用前,一次在调用期间(第一个对象会被丢弃,所以它后来...从表面看,这样做似乎效率低下,但它能保证正确的初始化——若只定义了一个过载的构建器,它没有初始化 t3;同时在t3 的定义里并没有规定“默认”的初始化方式,那么会产生什么后果 呢?

    71520

    Python面向对象特性 — 多继承【多继承顺序、新式类和经典类】

    上一篇文章讲述了多继承的概念、语法、代码演练、使用注意事项,有兴趣的可以看下,这篇文章是基于上篇文章的扩展科普,简单知道一下就好。...一、Python中的MRO —— 方法搜索顺序【多继承顺序】 所谓方法搜索顺序,就是让某个对象调用某个方法时,python的解释器是按照什么样的顺序在创建这个对象的类,以及父类之间搜索方法的。...新式类和经典类在便宜thin2.x和Python3.x之间的区别: 在python3.x中定义类时,如果没有指定父类,会默认使用object作为该类的基类,python3.x中定义的类都是新式类。...基于Python2.0 2.基于Python3.x 新式类和经典类在多继承时,会影响到方法的搜索顺序。...注意:为了保证编写的代码能够同时在python2.x和python3.x运行,今后在定义类时,如果没有父类,建议统一继承自object class 类名(object): pass

    54930

    C++继承中的对象模型与继承中构造和析构顺序

    继承中的对象模型 问题:从父类继承过来的成员,哪些属于子类对象中?...示例: class Base { public: int m_A; protected: int m_B; private: int m_C; //私有成员只是被隐藏了,但是还是会继承下去 };...,只是由编译器给隐藏后访问不到 继承中构造和析构顺序 子类继承父类后,当创建子类对象,也会调用父类的构造函数 问题:父类和子类的构造和析构顺序是谁先谁后?...<< endl; } }; void test01() { //继承中 先调用父类构造函数,再调用子类构造函数,析构顺序与构造相反 Son s; } int main() { test01...(); system("pause"); return 0; } 速记:构造时现有父亲后又儿子,析构顺序相反(白发送黑发) 总结:继承中 先调用父类构造函数,再调用子类构造函数,析构顺序与构造相反

    58020

    Java对象初始化顺序

    当查看初始化顺序的时候一切就变的清晰了: 1.main() 函数调用了 Lower 构造器。 2.Lower 的一个实例被准备好了。...5.Initializer 类为两个字段( upperString 和 lowerString )附上新字符串。...一旦发生了,upperString 和 lowerString 的引用都不再为空。 6.Initializer.initialize() 的调用完成,Upper 构造器也同样完成。...这是一个很好的例子,不仅方便我们如何注意一些创建对象的细节(或者知道去哪里查看 Java 编码规范,打印的或者在线的),还显示了为什么像这样写初始化是很糟糕的。...相反的,如果因为一些原因对某些字段的初始化不能在子类本身被完成,它将只需要它自己的某些初始化帮助类的变体。

    72410

    python 面向对象之继承顺序

    print('B') class C(A):     def __init__(self):         print('C') class D(B,C):         pass obj = D() 继承顺序如下图...构造函数只会执行一次,先从本身找,找不到,就去上层寻找,顺序如下: D->B->C->A 执行上面的代码,输出:B 为什么会输出B呢?...应该从A中查找,A如果没有,再找C,顺序如下: D->B->A->C 这种查询策略,叫做深度优先 这里没有所谓的对错,是2种查询策略,也叫继承策略 在不同的场景下,会选择不同的查询策略 从上面的例子可以看出...class C(A):     def __init__(self):         print('C') class D(B,C):         pass obj = D() 使用python3和python2...执行 结果都是C 总结: python2 经典类是按深度优先来继承的,新式类是按广度优先来继承的 python3 经典类和新式类都是统一按广度优先来继承的 在python2中,继承效率来讲,深度优先不如广度优先

    26720

    java类初始化顺序

    执行顺序优先级:静态块,main(),构造块,构造方法。...LoadBlock(); } } /********* 运行结果 **********/ 静态代码块 构造代码块 构造函数 构造代码块 构造函数 静态代码块只运行一次,构造代码块优先于构造函数 静态变量和普通变量...,执行顺序如下: 执行父类的静态代码块,并初始化父类静态成员变量 执行子类的静态代码块,并初始化子类静态成员变量 执行父类的构造代码块,执行父类的构造函数,并初始化父类普通成员变量 执行子类的构造代码块..., 执行子类的构造函数,并初始化子类普通成员变量 总结 java类初始化执行顺序如下: 父类静态变量 父类静态初始化块 子类静态变量 子类静态化初始化块 父类变量 父类初始化块 父类构造器 子类变量 子类初始化块...子类构造器 规律是 静态变量、静态代码块->普通变量、初始化块、构造器 因为静态代码块是跟类关联的,所以只执行一次,并且优先级最高 参考资料 java类初始化顺序

    85710

    java类的初始化和对象的创建顺序

    学习java编程思想--类的初始化p146 类的加载顺序 * 1加载器启动找到 xxx.class文件,通过extends关键字寻找基类,先加载基类 * 2类初始化先初始化static成员变量和static...---> * 2先初始化父类的static成员变量和static * 3再初始化本类的static成员变量和static * 类加载之后,对象创建开始 * 1先加载父类的非静态成员变量(静态成员变量在类初始化的时候已经加载...,非静态成员变量要随对象的创建而初始化) * 2先加载父类的构造函数 * 3再加载本类的非静态成员变量 * 4再加载本类的构造函数 * 总体: * -->表示顺序 * 父类-->子类 * 静态-->...6 * 1加载器启动找到 xxx.class文件,通过extends关键字寻找基类,先加载基类 7 * 2类初始化先初始化static成员变量和static---> 8 * 2先初始化父类的...static成员变量和static 9 * 3再初始化本类的static成员变量和static 10 * 类加载之后,对象创建开始加载 11 * 1先加载父类的非静态成员变量(静态成员变量在类初始化的时候已经加载

    1K160

    智能合约中不当的继承顺序

    不当的继承顺序: 在智能合约开发中,不当的继承顺序可能会导致意料之外的行为,尤其是在处理权限控制和函数覆盖时。当一个合约从多个父合约继承时,构造函数的执行顺序和函数的覆盖规则变得尤为重要。...不当继承顺序示例 假设我们有两个合约ParentA和ParentB,以及一个从这两个合约继承的子合约Child。...然而,在Solidity中,如果两个父合约定义了同名函数,则继承的顺序决定了哪个函数会被优先覆盖。...解决方案 要解决这个问题,我们需要调整继承顺序,确保Child合约能够调用正确的setOwner函数。...ParentA,这意味着ParentA的函数和状态变量会先于ParentB的被初始化。

    8710
    领券