枚举实现工厂模式

package  com .  lee . first1200  ;
 
public  interface  Car  {
 
        public  void  sayName ()  ;
}

package  com .  lee . first1200  ;
 
public  class  AudiCar  implements  Car  {
 
        @Override
        public  void  sayName ()  {
              System . out  . println (  "Audi" ) ;
        }
 
}

package  com .  lee . first1200  ;
 
public  class  BenzCar  implements  Car  {
 
        @Override
        public  void  sayName ()  {
              System . out  . println (  "Benz" ) ;
        }
      
}

package  com .  lee . first1200  ;
 
public  enum  CarFactory  {
 
      BENZ  {
 
              @Override
              public  Car  create ()  {
                    // TODO Auto-generated method stub
                    return  new  BenzCar ()  ;
              }
 
        } ,
      AUDI  {
 
              @Override
              public  Car  create ()  {
                    // TODO Auto-generated method stub
                    return  new  AudiCar ()  ;
              }
 
        } ,
      BMW  {
 
              @Override
              public  Car  create ()  {
                    // TODO Auto-generated method stub
                    return  new  BmwCar ()  ;
              }
 
        } ;
 
        public  abstract  Car  create () ;
 
}

package  com .  lee . first1200  ;
 
public  class  CarMain  {
 
        public  static  void  main ( String  []  args  )  {
            CarFactory  . BMW .  create () .  sayName () ;
 
            CarFactory  . AUDI .  create () .  sayName () ;
 
            CarFactory  . BMW .  create () .  sayName () ;
        }
}
不使用枚举实现策略工厂的方法通常涉及到使用映射(Map)来根据策略名称动态地创建策略实例。以下是实现策略工厂的一个基本步骤: 1. 定义策略接口:首先,定义一个策略接口,所有具体的策略实现都需要实现这个接口。 ```java public interface Strategy { void execute(); } ``` 2. 实现具体策略类:然后,为每种策略创建具体的实现类。 ```java public class ConcreteStrategyA implements Strategy { @Override public void execute() { // 具体实现A } } public class ConcreteStrategyB implements Strategy { @Override public void execute() { // 具体实现B } } ``` 3. 创建策略工厂:接着,实现一个策略工厂类,该类内部可以使用一个映射(Map)来关联策略名称和对应的策略实例。 ```java public class StrategyFactory { private static final Map<String, Strategy> strategies = new HashMap<>(); static { strategies.put("StrategyA", new ConcreteStrategyA()); strategies.put("StrategyB", new ConcreteStrategyB()); // 可以添加更多的策略映射 } public static Strategy getStrategy(String name) { if (name == null || name.isEmpty()) { throw new IllegalArgumentException("Strategy name cannot be null or empty."); } return strategies.get(name); } } ``` 4. 使用工厂获取策略实例:最后,在客户端代码中使用工厂类来获取具体的策略实例并执行策略方法。 ```java public class Client { public static void main(String[] args) { Strategy strategyA = StrategyFactory.getStrategy("StrategyA"); strategyA.execute(); Strategy strategyB = StrategyFactory.getStrategy("StrategyB"); strategyB.execute(); } } ``` 这种方法通过映射动态地关联策略名称和对应的策略实例,避免了枚举的使用,同时保持了策略模式的灵活性和扩展性。策略工厂可以根据实际需要动态地增加或删除策略映射。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值