反射+抽象工厂模式
优化
在抽象工厂模式的基础上,可以引入反射机制
来动态地创建产品对象,从而提高系统的灵活性和可扩展性。以下是使用反射和抽象工厂优化后的代码示例
1. 定义产品接口及其实现(保持不变)
public interface Shape {
void draw();
}
public class Circle implements Shape {
@Override
public void draw() {
System.out.println("Drawing a circle.");
}
}
public class Square implements Shape {
@Override
public void draw() {
System.out.println("Drawing a square.");
}
}
2.定义抽象工厂接口及映射表
定义一个抽象工厂接口,用于声明创建产品的方法。同时,定义一个静态映射表(Map),将产品类型字符串与对应的类名关联起来,以便通过反射创建对象。
import java.util.HashMap;
import java.util.Map;
public interface ShapeFactory {
// 映射表:产品类型 -> 类名
static final Map<String, String> SHAPE_CLASS_MAP = new HashMap<>();
static {
SHAPE_CLASS_MAP.put("circle", "com.example.Circle");
SHAPE_CLASS_MAP.put("square", "com.example.Square");
}
Shape createShape(String shapeType)
}
3.实现抽象工厂接口
实现抽象工厂接口,利用反射创建具体的产品对象。
import java.lang.reflect.Constructor;
import java.lang.reflect.InvocationTargetException;
public class ReflectionShapeFactory implements ShapeFactory {
@Override
public Shape createShape(String shapeType) {
try {
// 获取对应类名的Class对象
Class<?> clazz = Class.forName(ShapeFactory.SHAPE_CLASS_MAP.get(shapeType));
// 获取无参构造器并创建对象
Constructor<?> constructor = clazz.getDeclaredConstructor();
constructor.setAccessible(true);
return (Shape) constructor.newInstance();
} catch (ClassNotFoundException | NoSuchMethodException | IllegalAccessException |
InstantiationException | InvocationTargetException e) {
throw new RuntimeException("Failed to create shape: " + shapeType, e);
}
}
}
4.客户端代码
在客户端代码中,通过抽象工厂接口创建所需的产品,传入产品类型字符串。
public class Client {
public static void main(String[] args) {
// 创建一个具体工厂实例
ShapeFactory factory = new ReflectionShapeFactory();
// 使用工厂创建产品并进行操作
Shape circle = factory.createShape("circle");
circle.draw();
Shape square = factory.createShape("square");
square.draw();
}
}
在这个优化后的示例中,我们使用反射动态地创建产品对象,无需在工厂类中显式列出每个具体产品的创建方法。当需要添加新的形状类型时,只需更新映射表,无需修改工厂类的代码。这增强了系统的灵活性和可扩展性,但请注意,反射可能会带来一定的性能开销。在实际应用中,需根据需求权衡是否采用反射来优化抽象工厂模式。