Java抽象工厂模式

一、 基本介绍

  1. 抽象工厂模式:定义了一个interface用于创建相关或有依赖关系的对象簇,而无需指明具体的类。
  2. 抽象工厂模式可以将简单工厂模式工厂方法模式进行整合。
  3. 从设计层面看,抽象工厂模式就是对简单工厂模式的改进(或者称为进一步的抽象)。
  4. 将工厂抽象成两层,AbsFactory(抽象工厂) 和 具体实现的工厂子类。程序员可以根据创建对象类型使用对应的工厂子类。这样将单个的简单工厂类变成了工厂簇,更利于代码的维护和扩展。
  5. 类图
    在这里插入图片描述

二、代码:

Pizza类和其子类和上一篇文章的PIzza和其子类是一样的,这里代码只给出工厂类和其子类的代码:

//一个抽象工厂模式的抽象层(接口)
public interface AbsFactory {
	//让下面的工厂子类来 具体实现
	public Pizza createPizza(String orderType);
}
//这是工厂子类
public class BJFactory implements AbsFactory {
	@Override
	public Pizza createPizza(String orderType) {
		System.out.println("~使用的是抽象工厂模式~");
		// TODO Auto-generated method stub
		Pizza pizza = null;
		if(orderType.equals("cheese")) {
			pizza = new BJCheesePizza();
		} else if (orderType.equals("pepper")){
			pizza = new BJPepperPizza();
		}
		return pizza;
	}
}
public class LDFactory implements AbsFactory {

	@Override
	public Pizza createPizza(String orderType) {
		System.out.println("~使用的是抽象工厂模式~");
		Pizza pizza = null;
		if (orderType.equals("cheese")) {
			pizza = new LDCheesePizza();
		} else if (orderType.equals("pepper")) {
			pizza = new LDPepperPizza();
		}
		return pizza;
	}
}

public class OrderPizza {
	AbsFactory factory;

	// 构造器
	public OrderPizza(AbsFactory factory) {
		setFactory(factory);
	}

	private void setFactory(AbsFactory factory) {
		Pizza pizza = null;
		String orderType = ""; // 用户输入
		this.factory = factory;
		do {
			orderType = getType();
			// factory 可能是北京的工厂子类,也可能是伦敦的工厂子类
			pizza = factory.createPizza(orderType);
			if (pizza != null) { // 订购ok
				pizza.prepare();
				pizza.bake();
				pizza.cut();
				pizza.box();
			} else {
				System.out.println("订购失败");
				break;
			}
		} while (true);
	}

	// 写一个方法,可以获取客户希望订购的披萨种类
	private String getType() {
		try {
			BufferedReader strin = new BufferedReader(new InputStreamReader(System.in));
			System.out.println("input pizza 种类:");
			String str = strin.readLine();
			return str;
		} catch (IOException e) {
			e.printStackTrace();
			return "";
		}
	}
}

测试类代码:

public class PizzaStore {
	public static void main(String[] args) {
		new OrderPizza(new BJFactory());
	}

}

结果图:

在这里插入图片描述

三、工厂模式在JDK-Calendar 应用的源码分析:

JDK 中的Calendar类中,就使用了简单工厂模式:

在Calendar类中的静态方法getInstance中,其方法体中的return时用到了一个方法 createCalendar,这个方法的源码中就利用到了简单工厂模式,把需要实例化的类放到一个工厂中,这里也就是放到了createCalendar这个方法中来进行相对应的类的实例化。

四、工厂模式小结

1.工厂模式的意义

将实例化对象的代码提取出来,放到一个类中统一管理和维护,达到和主项目的依赖关系的解耦。从而提高项目的扩展和维护性。

2. 三种工厂模式 (简单工厂模式、工厂方法模式、抽象工厂模式)

3. 设计模式的依赖抽象原则

(1)创建对象实例时,不要直接 new 类, 而是把这个new 类的动作放在一个工厂的方法中,并返回。有的书上说,变量不要直接持有具体类的引用。

(2)不要让类继承具体类,而是继承抽象类或者是实现interface(接口)

(3) 不要覆盖基类中已经实现的方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java抽象工厂模式(Abstract Factory Pattern)是一种创建型设计模式,它提供了一种将一组相关的工厂组合起来创建对象的方式,而不必指定具体的类。 抽象工厂模式通常涉及一个抽象工厂类,它声明了用于创建一组相关对象的抽象方法。每个具体的工厂类都实现了这些抽象方法,以便创建一组特定的对象。这些具体的工厂类通常在运行时通过依赖注入或配置文件等方式被选择和实例化。 在抽象工厂模式中,客户端代码只与抽象工厂类和抽象产品类交互。这使得客户端代码能够与特定实现细节分离,从而更加灵活和可维护。 以下是Java抽象工厂模式的简单示例: ```java // 抽象工厂类 public interface AbstractFactory { public ProductA createProductA(); public ProductB createProductB(); } // 具体工厂类 1 public class ConcreteFactory1 implements AbstractFactory { public ProductA createProductA() { return new ConcreteProductA1(); } public ProductB createProductB() { return new ConcreteProductB1(); } } // 具体工厂类 2 public class ConcreteFactory2 implements AbstractFactory { public ProductA createProductA() { return new ConcreteProductA2(); } public ProductB createProductB() { return new ConcreteProductB2(); } } // 抽象产品类 public interface ProductA { public void methodA(); } // 具体产品类 1 public class ConcreteProductA1 implements ProductA { public void methodA() { System.out.println("ConcreteProductA1's methodA"); } } // 具体产品类 2 public class ConcreteProductA2 implements ProductA { public void methodA() { System.out.println("ConcreteProductA2's methodA"); } } // 抽象产品类 public interface ProductB { public void methodB(); } // 具体产品类 1 public class ConcreteProductB1 implements ProductB { public void methodB() { System.out.println("ConcreteProductB1's methodB"); } } // 具体产品类 2 public class ConcreteProductB2 implements ProductB { public void methodB() { System.out.println("ConcreteProductB2's methodB"); } } ``` 在这个示例中,抽象工厂类(AbstractFactory)声明了创建ProductA和ProductB的抽象方法。具体工厂类1(ConcreteFactory1)和具体工厂类2(ConcreteFactory2)都实现了这些方法,以便分别创建ConcreteProductA1和ConcreteProductB1或ConcreteProductA2和ConcreteProductB2等具体产品类的实例。这些具体工厂类可以通过依赖注入或配置文件等方式被选择和实例化。 客户端代码只需要通过抽象工厂类来创建ProductA和ProductB的实例,无需关心 ### 回答2: 抽象工厂模式是一种创建型设计模式,它提供了一种将相关的对象组织起来创建的方法。在Java中,抽象工厂模式由抽象工厂和具体工厂、抽象产品和具体产品组成。 抽象工厂是一个接口或抽象类,它声明了一组创建产品的方法,这些方法可以返回抽象产品或产品族。具体工厂实现了抽象工厂接口,并实现了具体的产品创建方法。 抽象产品定义了产品的通用特性和行为,而具体产品则继承或实现了抽象产品,并提供了具体的实现。 通过使用抽象工厂模式,我们可以轻松地添加或替换整个产品族,而无需修改客户端代码。客户端只需要通过抽象工厂接口来创建产品,而不需要关心具体的产品或产品族。 以下是使用Java实现抽象工厂模式的一个简单示例: ``` // 抽象产品A interface ProductA { void operationA(); } // 抽象产品B interface ProductB { void operationB(); } // 具体产品A1 class ConcreteProductA1 implements ProductA { @Override public void operationA() { System.out.println("ConcreteProductA1 operationA"); } } // 具体产品A2 class ConcreteProductA2 implements ProductA { @Override public void operationA() { System.out.println("ConcreteProductA2 operationA"); } } // 具体产品B1 class ConcreteProductB1 implements ProductB { @Override public void operationB() { System.out.println("ConcreteProductB1 operationB"); } } // 具体产品B2 class ConcreteProductB2 implements ProductB { @Override public void operationB() { System.out.println("ConcreteProductB2 operationB"); } } // 抽象工厂 interface AbstractFactory { ProductA createProductA(); ProductB createProductB(); } // 具体工厂1 class ConcreteFactory1 implements AbstractFactory { @Override public ProductA createProductA() { return new ConcreteProductA1(); } @Override public ProductB createProductB() { return new ConcreteProductB1(); } } // 具体工厂2 class ConcreteFactory2 implements AbstractFactory { @Override public ProductA createProductA() { return new ConcreteProductA2(); } @Override public ProductB createProductB() { return new ConcreteProductB2(); } } // 客户端代码 public class Client { public static void main(String[] args) { AbstractFactory factory = new ConcreteFactory1(); ProductA productA = factory.createProductA(); ProductB productB = factory.createProductB(); productA.operationA(); productB.operationB(); } } ``` 以上示例中,抽象工厂`AbstractFactory`定义了创建产品A和B的抽象方法。具体工厂`ConcreteFactory1`和`ConcreteFactory2`分别实现了抽象工厂接口,负责创建具体的产品A和B。具体的产品A和B都实现了对应的接口。在客户端代码中,我们可以通过切换具体工厂来创建不同的产品族,而无需修改客户端代码。 ### 回答3: 抽象工厂模式是一种创建型设计模式,它提供了一个抽象的工厂接口,用于创建一系列相关或依赖的对象,而无需指定其具体的类。通过使用该模式,我们可以将对象的创建和使用分离开来,提供更好的灵活性和可扩展性。 在Java中,抽象工厂模式通常由一个抽象工厂接口和多个具体工厂类来实现。抽象工厂接口定义了创建一系列产品对象的方法,而具体工厂类分别实现这些方法来创建具体的产品对象。 抽象工厂模式适用于需要创建一系列相关的产品对象的场景,例如创建不同类型的按钮和文本框组合。我们可以定义一个抽象按钮工厂接口和一个抽象文本框工厂接口,然后分别由多个具体按钮工厂类和文本框工厂类来实现这些接口。这样一来,当需要创建不同类型的按钮和文本框时,只需通过对应的工厂对象调用相应的方法即可,不需要关心具体的实现。 抽象工厂模式的优点是能够在不修改客户端代码的情况下引入新的产品系列,与客户端代码解耦。同时,它也能够保证所创建的对象是一致相关的,符合一定的规范。 然而,抽象工厂模式也存在一些缺点。由于每增加一个产品系列,就需要增加一个对应的具体工厂类,这样会使得系统的类的个数增加。同时,如果需要扩展产品对象的种类,就需要修改抽象工厂接口以及所有具体工厂类的实现,这样会对系统的扩展性造成一定的影响。 总的来说,抽象工厂模式在某些特定的场景下能够提供一种简便、灵活的对象创建方式,但同时也需要权衡其对系统复杂性和可扩展性的影响。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值