Java基础——静态内部类

在一个类中创建另外一个类,叫做成员内部类。这个成员内部类如果是静态的(利用static关键字修饰),就被称作静态内部类。

一、静态内部类的使用目的

在定义内部类的时候,在其前面加上一个权限修饰符static。这个内部类就变为了静态内部类。如在进行代码程序测试的时候,如果在每一个Java源文件中都设置一个主方法(主方法是某个应用程序的入口,必须具有),那么会出现很多额外的代码。而且最主要的是这段主程序的代码对于Java文件来说,只是一个形式,其本身并不需要这种主方法。但是少了这个主方法又是万万不行的。在这种情况下,就可以将主方法写入到静态内部类中,从而不用为每个Java源文件都设置一个类似的主方法。这对于代码测试是非常有用的。在一些中大型的应用程序开发中,则是一个常用的技术手段。

二、静态内部类的使用限制

将某个内部类定义为静态类,跟将其他类定义为静态类的方法基本相同,引用规则也基本一致。不过其细节方面仍然有很大的不同。具体来说,主要有如下几个地方要引起各位程序开发人员的注意。

1、静态成员(包括静态变量与静态成员)的定义

在非静态内部类中不可以声明静态成员。如现在在一个student类中定义了一个内部类Age,如果没有将这个类利用static关键字修饰,即没有定义为静态类,那么在这个内部类中如果要利用static关键字来修饰某个成员方法或者成员变量是不允许的。在编译的时候就通不过。故程序开发人员需要注意,只有静态内部类才能够定义静态的成员变量与成员方法。

2、在成员的引用上,有比较大的限制

一般的非静态内部类,可以随意的访问外部类中的成员变量与成员方法。即使这些成员方法被修饰为private(私有的成员变量或者方法)。因为在其他类中是无法访问被定义为私有的成员变量或方法。但是如果一个内部类被定义为静态的,那么在引用外部类的成员方法或者成员变量的时候,就会有诸多的限制。如不能够从静态内部类的对象中访问外部类的非静态成员(包括成员变量与成员方法)。这是什么意思呢?如果在外部类中定义了两个变量,一个是非静态的变量,一个是静态的变量。静态内部类只能引用外部类中的静态的成员(变量或方法),而不能够访问非静态的变量。对于那些非静态的成员变量与成员方法,在静态内部类中是无法访问的。这就是静态内部类的最大使用限制。在普通的非静态内部类中是没有这个限制的。也正是这个原因,决定了静态内部类只应用在一些特定的场合。其应用范围远远没有像非静态的内部类那样广泛。

3、创建静态内部类时不需要将静态内部类的实例绑定在外部类的实例上

通常情况下,在一个类中创建成员内部类的时候,有一个强制性的规定,即内部类的实例一定要绑定在外部类的实例中。也就是说,在创建内部类之前要先在外部类中要利用new关键字来创建这个内部类的对象。如此的话如果从外部类中初始化一个内部类对象,那么内部类对象就会绑定在外部类对象上。也就是说,普通非静态内部类的对象是依附在外部类对象之中的。通常情况下,程序员在定义静态内部类的时候,是不需要定义绑定在外部类的实例上的。也就是说,要在一个外部类中定义一个静态的内部类,不需要利用关键字new来创建内部类的实例。

4、书写形式

一般的书写形式:

public class Outter {
    /** 嵌套类,public等四种访问修饰符均可修饰*/
    public static class Inner {
        /** 嵌套类内部*/
    }
}

接口中的书写形式:

public interface OutInterface {
    /** 嵌套类,在接口中定义的任何类都自动的是public和static的,因此这两个关键字都可以省略*/
    class Inner {
        public void print() {
            System.out.println("print()");
        }
    }
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值