java 枚举 静态_关于java:静态枚举与非静态枚举

本问题已经有最佳答案,请猛点这里访问。

Java中的静态枚举和非静态枚举有什么区别? 两种用法都是一样的。

在启动时是否在内存中加载了所有静态的,并且按需加载了非静态的? del>是否正确?

如果是,那么哪种方法更好? 是否始终将一些数据保存在内存中或使用服务器资源加载它们?

public class Test {

public enum Enum1 {

A, B

}

public static enum Enum2 {

C, D

}

public static void main(String[] args) {

Enum1 a = Enum1.A;

Enum1 b = Enum1.B;

Enum2 c = Enum2.C;

Enum2 d = Enum2.D;

}

}

属性是指方法吗?

所有enum s实际上都是static。如果你有一个嵌套的枚举,它与static class非常相似。

所有类都是延迟加载的(枚举或其他类)但是当它们被加载时,它们会一次性加载。即你不能加载一些常量但不能加载其他常量(除了在类初始化过程中)

Java允许某些修饰符是隐式的,以避免必须一直声明它们。这意味着添加修饰符不一定能提供更长的写入相同内容的方法。

默认修饰符

class field / method / nested class - package local,non-final,non-static

枚举和嵌套枚举 - 包本地,最终和静态

接口字段 - public static final

接口方法 - public abstract

接口中的嵌套类 - public static,非final

注意:虽然static对于enum是可选的,但它始终是静态的。但是,无法为枚举设置final,即使它始终是final(从技术上讲,您可以使用具有重写的常量实现的子类)

编辑:static与enum一起使用的唯一地方是import static的枚举值。谢谢@ man910

它们可能是隐式的,但如果您在静态导入中转发它们,则仍需要将它们声明为静态。 例如,import static my.embedded.EnumType.SOME_VALUE;

尽管Groovy的前提是有效的Java是有效的Groovy,但在Groovy中并非如此:stackoverflow.com/a/54139042/885922

如果您正在讨论嵌套枚举,则默认情况下它们是隐式static。

根据Java语言规范:

Nested enum types are implicitly static. It is permissible to

explicitly declare a nested enum type to be static.

所有枚举都是隐式静态的,只是你不需要编写static关键字。与所有接口方法隐式公开的方式类似。

由于enums是inherently static,因此在enums中使用static-keyword时没有必要也没有区别。

如果枚举是类的成员,则它是隐式静态的。

接口可能包含成员类型声明。接口中的成员类型声明是隐式静态和公共的。

Oracle社区论坛和讨论

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
懒加载也叫延迟加载,是一种常用的性能优化方式。它的基本思想是,将对象的创建过程推迟到真正需要使用该对象时再进行,从而避免了不必要的资源浪费和时间消耗。Java中实现懒加载的方式有多种,下面介绍几种常见的方式。 1. 双重检查锁定 双重检查锁定是一种常见的线程安全的懒加载实现方式。其基本思路是,在对象创建的时候进行一次非线程安全的检查,如果对象已经被创建,则直接返回该对象;如果对象还未被创建,则加锁创建对象并返回。这种方式可以避免在多线程环境下重复创建对象,从而提高性能。 ``` public class Singleton { private volatile static Singleton instance; private Singleton() {} public static Singleton getInstance() { if (instance == null) { synchronized (Singleton.class) { if (instance == null) { instance = new Singleton(); } } } return instance; } } ``` 2. 静态内部类 静态内部类是另一种常见的懒加载实现方式。其基本思路是,在外部类中创建一个静态内部类,在静态内部类中创建需要懒加载的对象。由于静态内部类只有在被调用时才会被加载,因此可以实现懒加载的效果。 ``` public class Singleton { private Singleton() {} private static class SingletonHolder { private static final Singleton INSTANCE = new Singleton(); } public static Singleton getInstance() { return SingletonHolder.INSTANCE; } } ``` 3. 枚举类枚举类型是一种常见的懒加载实现方式。枚举类型中的每个枚举常量都是在第一次访问时被创建的,因此可以实现懒加载的效果。同时,由于枚举类型是线程安全的,并且可以保证单例模式的正确性,因此也是一种较为优秀的实现方式。 ``` public enum Singleton { INSTANCE; public void doSomething() { // ... } } ``` 以上是几种常见的Java懒加载实现方式,可以根据具体情况选择适合自己的方式进行实现。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值