经典Java面试题:static加载机制你知道吗?_static面试

访问静态属性

调用静态方法

主动加载:Class.forName(“全限定名”)

二. static 特点

被static关键字修饰的类或方法、成员等具有如下特点:

静态方法允许直接访问静态成员;

静态方法不能直接访问非静态成员;

静态方法中不允许使用this或是super关键字;

静态方法可以继承,不能重写、没有多态。

三. 经典面试题

接着我们再来看看关于static的一个经典面试题,代码案例如下:

public class Test {
   
    public static int k = 0;
    public static Test t1 = new Test("t1");
    public static Test t2 = new Test("t2");
    public static int i = print("i");
    public static int n = 99;
    
    private int a = 0;
    
    public int j = print("j");
    
    {
        print("构造代码块");
    }
    
    static{
        print("静态构造代码块");
    }
    
    public Test(String str){
        System.out.println((++k)+":"+str+"  i="+i+"  n="+n);
        ++i;
        ++n;
    }
    
    public static int print(String str){
        System.out.println((++k)+":"+str+" i="+i+" n="+n);
        ++n;
        return ++i;
    }
    
    public static void main(String[] args) {
                
    }
}

这是一道关于static加载执行顺序的经典面试题,根据代码观察执行结果,接下来我们就来分析一下上述代码的执行结果是什么。

1.在执行 main 方法,也就是程序主入口的时候,首先会加载所在的类,声明静态变量,初始化静态属性,执行静态代码块(按照顺序执行),所以首先加载的是:

 public static int k = 0;

2.其次加载:

public static Test t1 = new Test("t1");

3.而加载到实例化 t1 对象时,类的加载会暂停,然后创建 Test 的实例对象。在创建 Test 对象时则会先加载属性再执行代码块,最后执行构造方法,所以先执行的会是实例属性。

private int a = 0;
public int j = print("j");

public static int print(String str){
    System.out.println((++k)+":"+str+" i="+i+" n="+n);
    ++n;
    return ++i;
}

4.因加载类的过程中,会对定义的静态字段在方法区中分别分配空间,并赋予初始化值,所以 i 和 n 的值都为0,因此第一个打印语句是:

1:j i=0 n=0

5.实例属性加载完毕后,则进行构造代码块的加载:

{
    print("构造代码块");
}

public static int print(String str){
    System.out.println((++k)+":"+str+" i="+i+" n="+n);
    ++n;
    return ++i;
}

6.因为第一次调用时已经对 k 、i 、n 的值进行了自加,因此第二个打印语句是:

2:构造代码块 i=1 n=1

7.实例化对象的最后一步,则是执行构造方法:

public static Test t1 = new Test("t1");

public Test(String str){
    System.out.println((++k)+":"+str+"  i="+i+"  n="+n);
    ++i;
    ++n;
}

8.因此第三个打印语句是:

3:t1  i=2  n=2

9.t1 对象创建完毕后,类加载则继续执行,因此下一步则是:

给大家的福利

零基础入门

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

同时每个成长路线对应的板块都有配套的视频提供:

在这里插入图片描述

因篇幅有限,仅展示部分资料

网络安全面试题

绿盟护网行动

还有大家最喜欢的黑客技术

网络安全源码合集+工具包

所有资料共282G,朋友们如果有需要全套《网络安全入门+黑客进阶学习资源包》,可以扫描下方二维码领取(如遇扫码问题,可以在评论区留言领取哦)~

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以点击这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 22
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值