内部类、静态内部类-延迟加载

外部类加载顺序:
1、外部类初次加载,会初始化静态变量、静态代码块、静态方法,但不会加载内部类和静态内部类。
2、实例化外部类,调用外部类的静态方法、静态变量,则外部类必须先进行加载,但只加载一次。
3、直接调用静态内部类时,外部类不会加载。

内部类加载顺序:
在初次调用的时候加载,且只加载一次

package com.panda;

/**
 * author: ysd
 * Date: 2020/1/9
 * Description:内部类、静态内部类,延迟加载
 */
public class PandaInnerClass {

    static {
        System.out.println("我是 PandaInnerClass 的静态代码块。。");
    }

    public PandaInnerClass() {
        System.out.println("我是 PandaInnerClass 的无参构造");
    }

    public PandaInnerClass(String flag) {
        System.out.println("我是 PandaInnerClass 的有参构造,参数是" + flag);
    }

    class InnerClass {

        private PandaInnerClass innerClass = new PandaInnerClass("普通内部类。。");
    }

    static class StaticInnerClass {

        private static PandaInnerClass innerClass = new PandaInnerClass("静态内部类。。");
        static {
            System.out.println("我是静态内部类的 StaticInnerClass 的静态代码块。。");
        }

        public static void load() {
            System.out.println("静态load方法。。");
        }
    }

    public static PandaInnerClass getInstance() {
        return StaticInnerClass.innerClass;
    }
    public static void main(String[] args){
        System.out.println("let us  go ..");
        PandaInnerClass.StaticInnerClass.load();
        PandaInnerClass ok = StaticInnerClass.innerClass;
        PandaInnerClass hello = ok.new InnerClass().innerClass;
    }
}

执行结果

我是 PandaInnerClass 的静态代码块。。
let us  go ..
我是 PandaInnerClass 的有参构造,参数是静态内部类。。
我是静态内部类的 StaticInnerClass 的静态代码块。。
静态load方法。。
我是 PandaInnerClass 的有参构造,参数是普通内部类。。

解释:
1、jvm执行main方法,加载PandaInnerClass 类,加载静态代码块,输出我是 PandaInnerClass 的静态代码块。。

2、执行 System.out.println(“let us go …”); 控制台输出let us go .
.
3、执行PandaInnerClass.StaticInnerClass.load();调用静态内部类StaticInnerClass,加载StaticInnerClass,
先加载她得静态属性,执行PandaInnerClass的有参构造,输出我是 PandaInnerClass 的有参构造,参数是静态内部类。。
然后加载静态代码块,输出我是静态内部类的 StaticInnerClass 的静态代码块。。,
然后调用load方法,输出静态load方法。。

4、执行 PandaInnerClass hello = ok.new InnerClass().innerClass;调用内部类InnerClass,加载内部类InnerClass,调用innerClass属性,执行PandaInnerClass的构造函数,输出我是 PandaInnerClass 的有参构造,参数是普通内部类。。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中的单例模式是一种设计模式它确保一个类只有一个实例,并提供一个全局访问点访问该实例。静态内部类是一种常用的实现单例模式的方式。 在使用静态内部类实现单例模式时,我们将单例类的构造方法私有化,以防止外部直接创建实例。然后,我们在单例类中定义一个静态内部类,该内部类持有一个单例实例,并在静态代码块中初始化该实例。通过静态内部类的方式,我们可以保证在需要使用单例实例时才会创建它,而且只会创建一次。 以下是使用静态内部类实现单例模式的示例代码: ```java public class Singleton { private Singleton() { // 私有化构造方法 } private static class SingletonHolder { private static final Singleton INSTANCE = new Singleton(); } public static Singleton getInstance() { return SingletonHolder.INSTANCE; } } ``` 在上面的代码中,Singleton类的构造方法被私有化,确保外部无法直接创建实例。SingletonHolder是一个静态内部类,它持有一个Singleton实例,并在静态代码块中初始化该实例。getInstance()方法返回SingletonHolder中的实例,保证了单例的唯一性。 使用静态内部类实现单例模式的优点是延迟加载和线程安全。由于静态内部类的特性,只有在第一次调用getInstance()方法时才会加载SingletonHolder类,从而创建单例实例。同时,由于类加载是线程安全的,所以静态内部类实现的单例模式也是线程安全的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值