牛客刷题 类加载的顺序

简介: 牛客刷题 类加载的顺序
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。

相关文章
|
7月前
|
存储 算法 Java
手撕Java集合——链表
手撕Java集合——链表
面试又被问懵了吗?不如把ThreadLocal拆开了揉碎看看
1.为什么用 ThreadLocal? 所谓并发,就是有限资源需要应对远超资源的访问。解决问题的方法,要么增加资源应对访问;要么增加资源的利用率。 所以,相信这年头做开发的多多少少,都会那么几个“线程二三招”、“用锁五六式”。 那所带来的就是多线程访问下的并发安全问题。 共享变量的访问域跨越了原始的单线程,进入了千家万户的线程眼里。谁都可以用,谁都可以改,那不就打起来了吗? 因此,防止并发问题的最好办法,就是不要多线程访问(这科技水平倒退二十年~)。ThreadLocal 顾名思义,将一个变量限制为“线程封闭”:对象只被一个线程持有、访问、修改。
|
算法 Java
[java刷算法]牛客—剑指offer链表复习、手写简易正则匹配
✨今日三剑 JZ17 打印从1到最大的n位数 JZ18 删除链表的节点 JZ19 正则表达式匹配
[java刷算法]牛客—剑指offer链表复习、手写简易正则匹配
|
Java
【蓝桥Java每日一题】——11.做菜顺序(贪心秒杀困难题)
今天给大家带来一道级别是困难的力扣题,但是利用贪心思想我们可以很快速地做出来,甚至称之为简单题也不为过,可见贪心之强大
212 0
|
机器学习/深度学习 算法
一看就懂,一写就懵?搞懂回溯算法,一口气刷了20多道题(上)
回溯算法实际上一个类似枚举的搜索尝试过程,主要是在搜索尝试过程中寻找问题的解,当发现已不满足求解条件时,就“回溯”返回,尝试别的路径。——摘自《百度百科》
217 0
一看就懂,一写就懵?搞懂回溯算法,一口气刷了20多道题(上)
|
算法
一看就懂,一写就懵?搞懂回溯算法,一口气刷了20多道题(中)
回溯算法实际上一个类似枚举的搜索尝试过程,主要是在搜索尝试过程中寻找问题的解,当发现已不满足求解条件时,就“回溯”返回,尝试别的路径。——摘自《百度百科》
402 0
一看就懂,一写就懵?搞懂回溯算法,一口气刷了20多道题(中)
(二十)看完这篇类的实例化顺序,考执行顺序的面试题就难不倒你了
一段代码的执行顺序经常会放到面试题或者笔试题中,比如父类静态数据,构造函数,字段,子类静态数据,构造函数,字段,它们的执行顺序,关于这一类题目只要了解了类的实例化顺序,就不会再成为问题。先看一下下面的面试题
|
存储 编译器
懂了嘎嘎乱杀,但我赌你会懵——指针进阶终极版
正片开始👀 细化指针这一部分内容,现在着重把一些指针的运用情景搬出来康康,如果对指针盘的非常熟练了,或者指针还出于入门阶段的铁子请绕道(晕头警告) 直接给大家盘个套餐: 一维数组👏
懂了嘎嘎乱杀,但我赌你会懵——指针进阶终极版
|
Java 程序员 Linux
面经手册 · 第24篇《为了搞清楚类加载,竟然手撸JVM!》
写个代码加载下 1. 案例工程 2. 代码讲解 五、解析字节码文件 1. 提取部分字节码 2. 解析魔数并校验 3. 解析版本号信息 4. 解析全部内容对照
165 0
面经手册 · 第24篇《为了搞清楚类加载,竟然手撸JVM!》