将关联零件组装成产品的 Abstract Factory模式

Abstract Factory模式

应用场景

  • 希望一个系统不应当依赖于产品类实例如何被创建、组合和表达的细节时。
  • 一个系统有多于一个的产品族, 而系统只消费其中某一产品族。

本质

  • 选择产品族的实现

优点

  • 增加产品族: Abstract Factory很好的支持了"开放一封闭"原则。

缺点

  • 增加新产品的等级结构:需要修改所有的工厂角色,没有很好支持“开放一封闭”原则。

角色

  • 产品族(Product Family):
    所谓产品族,是指位于不同产品等级结构,功能相关联的产品组成的家族。

  • 抽象工厂(Abstract Factory)角色:
    担任这个角色的是工厂方法模式的核心,它是与应用系统商业逻辑无关的。

  • 具体工厂(Concrete Factory) 角色:
    这个角色直接在客户端的调用下创建产品的实例。这个角色含有选择合适的产品对象的逻辑,而这个逻辑是与应用系统的商业逻辑紧密相关的。

  • 抽象产品( Abstract Product)角色:
    担任这个角色的类是工厂方法模式所创建的对象的父类,或它们共同拥有的接口。

  • 具体产品( Concrete Product)角色:
    抽象工厂模式所创建的任何产品对象都是某一个具体产品类的实例。这是客户端最终需要的东西,其内部一定充满不应用系统的商业逻辑。

Abstract Factory模式的类图

在这里插入图片描述

示例程序

示例程序的类图

在这里插入图片描述

示例代码
public class User {

	private int id;
	private String name;
	public User() {}
	public User(int id, String name) {
		super();
		this.id = id;
		this.name = name;
	}
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
}
public interface IUser {
	void insert(User user);
	void getUser(int id);
}
public class AccessUser implements IUser {

	@Override
	public void insert(User user) {
		System.out.println("Access --> INSERT INTO user( id , name ) VALUES( " + user.getId() + " , " + user.getName() + " )");
	}

	@Override
	public void getUser(int id) {
		System.out.println("Access --> SELECT * FROM user WHERE ID = " + id);
	}

}
public class SqlServerUser implements IUser {

	@Override
	public void insert(User user) {
		System.out.println("SQLServer --> INSERT INTO user( id , name ) VALUES( " + user.getId() + " , " + user.getName() + " )");
	}

	@Override
	public void getUser(int id) {
		System.out.println("SQLServer --> SELECT * FROM user WHERE ID = " + id);
	}

}
public class Department {

	private int id;
	private String name;
	public Department() {}
	public Department(int id, String name) {
		super();
		this.id = id;
		this.name = name;
	}
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	
}
public interface IDepartment {

	void insert(Department department);
	void getDepartment(int id);
}
public class AccessDepartment implements IDepartment {

	@Override
	public void insert(Department department) {
		System.out.println("Access --> INSERT INTO department( id , name ) VALUES( " + department.getId() + " , " + department.getName() + " )");

	}

	@Override
	public void getDepartment(int id) {
		System.out.println("Access --> SELECT * FROM department WHERE ID = " + id);

	}
}
public class SqlServerDepartment implements IDepartment {

	@Override
	public void insert(Department department) {
		System.out.println("SQLServer --> INSERT INTO department( id , name ) VALUES( " + department.getId() + " , " + department.getName() + " )");

	}

	@Override
	public void getDepartment(int id) {
		System.out.println("SQLServer --> SELECT * FROM department WHERE ID = " + id);

	}
}
public interface IFactory {

	IUser creatUser();
	IDepartment creatDepartment();
}
public class AccessFactory implements IFactory {

	@Override
	public IUser creatUser() {
		return  new AccessUser();
	}

	@Override
	public IDepartment creatDepartment() {
		return new AccessDepartment();
	}

}
public class SqlServerFactory implements IFactory {

	@Override
	public IDepartment creatDepartment() {
		return new SqlServerDepartment();
	}

	@Override
	public IUser creatUser() {
		return new SqlServerUser();
	}
}
public static void main(String[] args) {
		        /**
		         * 使用抽象工厂模式
		         * 更改生成的工厂类别即可更换数据库
		         */
		        User user = new User();
		        //IFactory factory = new SqlServerFactory();
		        IFactory factory = new AccessFactory();
		        IUser iUser = factory.creatUser();
		        iUser.insert(user);
		        iUser.getUser(1);

		        Department department = new Department();
		        IDepartment iDepartment = factory.creatDepartment();
		        iDepartment.insert(department);
		        iDepartment.getDepartment(1);
		    }

拓展思路

  • 易于增加具体的工厂
  • 难以增加新的零件

相关设计模式

  • Builder 模式(第7章)
    Abstract Factory模式通过调用抽象产品的接口( API )来组装抽象产品,生成具有复杂结构的实例。
    Builder模式则是分阶段地制作复杂实例。

  • Factory Method模式(第4章)
    有时Abstract Factory模式中零件和产品的生成会使用到Factory Method模式。

  • Composite模式(第11章)
    有时Abstract Factory模式在制作产品时会使用Composite 模式。

  • Singleton 模式(第5章)
    有时Abstract Factory模式中的具体工厂”会使用Singleton模式。

满足的原则

  • 开放封闭原则
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: Abstract Factory 模式是一种创建型设计模式,它提供了一种创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。这个模式的主要目的是将客户端代码与具体类的创建分离,从而使客户端代码能够与抽象接口进行交互,而不是与具体实现进行交互。 ### 回答2: Abstract Factory 模式是一种软件设计模式,它提供了一种创建相关或依赖对象族的方法。它属于创建型模式的一种。 Abstract Factory 模式的核心思想是将具体对象的实例化操作封装到接口中,由工厂类来创建这些实例。这样可以隐藏对象的具体实现细节,使得系统更加灵活、可扩展和易于维护。 在 Abstract Factory 模式中,有四个角色: 1. 抽象工厂(Abstract Factory):定义了一系列创建抽象产品对象的方法,所有具体工厂类必须实现这些方法。 2. 具体工厂(Concrete Factory):实现了抽象工厂中定义的创建产品对象的方法,返回具体产品的实例。 3. 抽象产品Abstract Product):定义了产品对象的通用接口,具体产品类必须实现这些接口。 4. 具体产品(Concrete Product):实现了抽象产品中定义的接口,是具体工厂创建的对象。 Abstract Factory模式是工厂方法模式的升级版,它在产品族的维度上进行了扩展。工厂方法模式只能创建单一类型的产品,而Abstract Factory模式能创建多个类型的产品。这使得Abstract Factory模式更加符合开闭原则,可以方便地扩展新的产品系列。 使用Abstract Factory模式可以将产品的创建和使用解耦,客户端只需要通过抽象接口来获取产品,不用关心具体的实现。同时,具体工厂负责创建产品,符合单一职责原则,提高了代码的可读性和可维护性。 总之,Abstract Factory模式提供了一种抽象的方式来创建相关的对象族,可以有效地降低系统的耦合性,提高系统的灵活性和可扩展性。但是它也增加了系统的复杂性,因此在设计系统时需要权衡利弊。 ### 回答3: Abstract Factory 模式是一种创建型设计模式,它提供了一种创建一系列相关或依赖对象的方法。它通过提供一个接口来创建一组相关的对象,而无需指定具体的类。 在 Abstract Factory 模式中,有一个抽象工厂类,它定义了创建对象的方法。具体的工厂类继承自抽象工厂类,并实现了其中的方法,用于创建具体的对象。每个具体工厂类创建一组相关的对象,这些对象在抽象工厂类中定义的接口下进行操作。 Abstract Factory 模式的最大优势是将客户端代码与具体类解耦,使得具体类的变化不会影响到客户端代码。客户端通过使用抽象工厂类和抽象产品类进行编程,而不是直接依赖于具体的对象。这样,如果需要更换一套创建对象的逻辑,只需要更换具体的工厂类即可,而无需修改客户端代码。这种灵活性使得 Abstract Factory 模式非常适合多对象产品系列的创建。 Abstract Factory 模式还可以保证创建的对象相互之间有关联,从而保持了系统的一致性。在具体工厂类中,只会创建相关的对象,并确保这些对象是一起工作的,它们之间有相互依赖关系。因此,使用 Abstract Factory 模式可以确保一组对象能够协同工作,实现系统的完整功能。 总而言之,Abstract Factory 模式通过提供一个接口来创建一组相关的对象,使得客户端代码与具体类解耦,并保持对象之间的关联。它能够提供灵活性和扩展性,适用于多对象产品系列的创建。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

莫余

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值