枚举工厂

优点:
1.避免错误调用的发生
一般工厂方法模式中产生方法(也就是createcar方法)可以接受三种类型的参数:类型参数、String参数(产生方法中判断String参数是需要产生什么产品)、int参数(根据int值判断需要生产什么类型的产品),这三种参数都是宽泛的数据类型,很容易产生错误(比如边界值问题、null值问题),而且出现这类错误编辑器还不会报警。而使用枚举类型的工厂方法模式就不存在该问题了。不需要传递任何参数,只需要选择好生产什么类型的产品即可。
2.性能好,使用便捷
枚举类型的计算是以int类型的计算为基础的,这是最基本的操作,性能当然会快,至于使用便捷,注意看客户端的调用,代码的字面意思就是“汽车工厂,我需要一辆别克汽车,赶快生产”。
3.降低类间耦合
不管生产方法接收的是Class、String还是int 的参数,都会成为客户端类的负担,这些类并不是客户端需要的,而是因为工厂方法的限制必须输入的,例如Class参数,对客户端main方法来说,它需要传递一个FordCar.class参数才能生产一辆福特汽车,除了在create 方法中传递该参数外,业务类不需要改Car的实现类,这严重违背了迪米特原则(Law of Demeter ,简称 LoD),也就是最少知识原则:一个对象应该对其他对象有最少的了解。

实现一:

public enum ZooFactory {

    JERRY{
        public Zoo newZoo() {
            return new Jerry();

        }
    },
    TOM{
        public Zoo newZoo() {
            return new Tom();

        }


    };

    public abstract Zoo newZoo();
}
public class Jerry implements Zoo{

    @Override
    public void run() {
        System.out.println("Jerry run");
    }

}
public class Tom implements Zoo{

    @Override
    public void run() {
        System.out.println("Tom run");
    }

}
public interface Zoo {

    public void run();
}

第二种方式:

public class ZooFactory {
    public enum CarFactory {  
        JREEY, TOM;  
        public Zoo create() {  
            switch (this) {  
            case JREEY:  
                return new Jerry();  
            case TOM:  
                return new Tom();  
            default:  
                throw new AssertionError("无效参数");  
            }  
        }  
    }  
}
### Java 反射获取 Enum 型实例的方法 在 Java 中,可以通过反射机制来操作 `Enum` 型。以下是几种常见的方法用于获取枚举型的实例及相关信息。 #### 使用 `Class.getEnumConstants()` 方法 该方法可以直接返回指定枚举的所有枚举常量数组。如果目标不是枚举型,则返回 `null`[^1]。 ```java public static void getEnumConstantsExample() { try { Class<?> clazz = Class.forName("YourEnumClassName"); Object[] constants = clazz.getEnumConstants(); if (constants != null) { System.out.println(Arrays.toString(constants)); } else { System.out.println("The class is not an enum."); } } catch (ClassNotFoundException e) { e.printStackTrace(); } } ``` #### 判断字段是否为枚举常量 可以利用 `Field.isEnumConstant()` 来判断某个字段是否代表了一个枚举型的元素[^2]。 ```java public static void checkIfFieldIsEnumConstant(Class<?> clazz, String fieldName) throws NoSuchFieldException { Field field = clazz.getField(fieldName); boolean isEnumConst = field.isEnumConstant(); // true 如果是枚举常量 System.out.println("Is '" + fieldName + "' an enum constant? " + isEnumConst); } ``` #### 创建特定的枚举实例 通过 `Enum.valueOf(Class<T> enumType, String name)` 静态方法可以根据名称创建对应的枚举实例[^3]。 ```java public static <T extends Enum<T>> T createEnumInstance(Class<T> enumType, String name) { return Enum.valueOf(enumType, name); // 抛出 IllegalArgumentException 若无匹配项 } // 调用示例 Color color = createEnumInstance(Color.class, "RED"); // 假设 Color 是一个枚举 System.out.println(color); ``` #### 枚举加载与初始化行为 需要注意的是,在使用反射访问枚举时,可能会触发的初始化过程。这是因为枚举本质上是一个特殊的,其所有常量会在第一次被引用时完成静态初始化[^4]。 --- ### 总结 上述方法涵盖了如何通过反射获取整个枚举集合、验证单个字段是否属于枚举以及动态生成具体枚举对象的过程。每种方式都有各自的适用场景,开发者应根据实际需求灵活选用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值