牛客刷题 类加载的顺序

简介: 牛客刷题 类加载的顺序
public class Base
{
    private String baseName = "base";
    public Base()
    {
        callName();
    }
    public void callName()
    {
        System. out. println(baseName);
    }
    static class Sub extends Base
    {
        private String baseName = "sub";
        public void callName()
        {
            System. out. println (baseName) ;
        }
    }
    public static void main(String[] args)
    {
        Base b = new Sub();
    }
}


输出:null


1.首先,需要明白类的加载顺序。


(1) 父类静态代码块(包括静态初始化块,静态属性,但不包括静态方法)


(2) 子类静态代码块(包括静态初始化块,静态属性,但不包括静态方法 )


(3) 父类非静态代码块( 包括非静态初始化块,非静态属性 )


(4) 父类构造函数


(5) 子类非静态代码块 ( 包括非静态初始化块,非静态属性 )


(6) 子类构造函数


其中:类中静态块按照声明顺序执行,并且(1)和(2)不需要调用new类实例的时候就执行了(意思就是在类加载到方法区的时候执行的)


2.其次,需要理解子类覆盖父类方法的问题,也就是方法重写实现多态问题。


Base b = new Sub();它为多态的一种表现形式,声明是Base,实现是Sub类, 理解为 b 编译时表现为Base类特性,运行时表现为Sub类特性。


当子类覆盖了父类的方法后,意思是父类的方法已经被重写,题中 父类初始化调用的方法为子类实现的方法,子类实现的方法中调用的baseName为子类中的私有属性。


由1.可知,此时只执行到步骤4.,子类非静态代码块和初始化步骤还没有到,子类中的baseName还没有被初始化。所以此时 baseName为空。 所以为null。

相关文章
|
11月前
|
存储 算法 Java
《代码随想录》刷题笔记——哈希表篇【java实现】
《代码随想录》刷题笔记——哈希表篇【java实现】
72 0
|
11月前
|
算法 C++ 索引
代码随想录刷题-数组
代码随想录刷题-数组
47 0
|
11月前
|
Java
《代码随想录》刷题笔记——链表篇【java实现】
《代码随想录》刷题笔记——链表篇【java实现】
79 0
|
11月前
|
存储 搜索推荐 Java
《代码随想录》刷题笔记——数组篇【java实现】
《代码随想录》刷题笔记——数组篇【java实现】
81 0
|
算法 Linux C语言
几道数组相关的面试题
几道数组相关的面试题
78 0
几道数组相关的面试题
|
C语言
【leetcode】学了栈和队列却觉得无用武之地?试试这几道题目吧!
【leetcode】学了栈和队列却觉得无用武之地?试试这几道题目吧!
83 0
|
人工智能 算法 大数据
终于有人把面试必考的动态规划、链表、二叉树、字符串全部撸完了
对于计算机专业的毕业生而言,算法岗基本上就是**「高薪」**的代名词。 然而,由于这几年AI方向异常火爆,算法岗似乎也已经承载不下了,计算机视觉就是一个很好的例子,某些公司的录用比例已经达到了**32:1**。 知乎上的问题也从**「是否值得进入」**到**「供大于求」**再到**「诸神黄昏」**、**「灰飞烟灭」**、**「车毁人亡」**,一年比一年夸张。
103 0
终于有人把面试必考的动态规划、链表、二叉树、字符串全部撸完了
|
算法
我明白了,leetcode91题
91题**解码方法**的难度属于中等,但其涉及到的知识并不少呢,斐波那契、备忘录剪枝、动态规划等等,除了题解之外,我也会深入浅出的讲解这些知识点,文章末尾我还会使用 正则 + 斐波那契的写法来解题,我们一起来看看。
131 0
我明白了,leetcode91题
|
算法 Java
[java刷算法]牛客—剑指offer链表复习、手写简易正则匹配
✨今日三剑 JZ17 打印从1到最大的n位数 JZ18 删除链表的节点 JZ19 正则表达式匹配
[java刷算法]牛客—剑指offer链表复习、手写简易正则匹配