[设计模式]工厂方法模式

     工厂方法模式(Factory Patern),是创建型设计模式之一。工厂方法模式是一种结构简单的模式;

定义

定义一个用于创建对象的接口,让子类决定实例化哪个类。

使用场景

在任何需要生成复杂对象的地方,都可以使用工厂方法模式。复杂对象适合使用工厂模式,用new就可以完成创建的对象无需使用工厂模式。

UML类图

示例

public abstract class Product {
	/**
	 * 产品类的抽象方法
	 * 由具体的产品类去实现
	 */
	public abstract void method();
}

public class ConcreteProductA extends Product {

	@Override
	public void method() {
		System.out.println("具体的产品A");
	}

}

public class ConcreteProductB extends Product {

	@Override
	public void method() {
		System.out.println("具体的产品B");
	}

}

public abstract class Factory {
	/**
	 * 抽象工厂方法
	 * 具体生产什么由子类去实现
	 * @return 具体的产品对象
	 */
	public abstract Product createProduct();  //方式一
	
	/**
	 * 
	 * @param cls  产品对象类类型
	 * @return 具体的产品对象
	 */
	public abstract <T extends  Product> T createProduct(Class<T> cls);  //方式二

}

public class ConcreteFactory extends Factory {

	@Override
	public Product createProduct() {   //方式一
		return new ConcreteProductA() ;
	}

	@Override
	public <T extends Product> T createProduct(Class<T> cls) {   //方式二
		Product p = null;
		try{
			p = (Product) Class.forName(cls.getName()).newInstance();
		}catch(Exception e){
			e.printStackTrace();
		}
		return (T) p;
	}

}

public class Main {
	public static void main(String[] args) {
		Factory factory = new ConcreteFactory();
		Product p = factory.createProduct();
		p.method();
	}
}

示例中主要分为四大模块,一是抽象工厂,其为工厂方法模式的核心;二是具体工厂,其实现了具体的业务逻辑;三是抽象产品,是工厂方法模式所创建的产品的父类;四是

具体产品,为实现抽象产品的某个具体产品的对象。

示例中Factory包含一个利用反射的方式实现的工厂方法方式,此时,需要在工厂方法的参数列表中传入一个Class类来决定是哪一个产品类。这种方法比较简洁、动态、如

果不喜欢这种方式,也可以尝试为每一个产品都定义一个具体的工厂。

当我们的工厂只有一个的时候,,那么可以简化掉抽象类是没问题的,只需要将对应的工厂方法改为静态方法即可。

public static Product createProduct1(){
		return new ConcreteProductB();
	}public static Product createProduct1(){
		return new ConcreteProductB();
	}

这种方式又称为简单工厂或静态工厂,它是工厂方法模式的一个弱化版本。

总结

工厂方法模式是一个很好的设计模式,是完全符合设计原则的,其降低了对象之间的耦合度,而且,工厂方法模式依赖于抽象的架构,其将实例化的任务交由子类去完成,

有非常好的扩展性。

缺点:每次我们为工厂方法模式添加新的产品时就要编写一个新的产品类,同时还要引入抽象层,这必然会导致类结构的复杂化,所以,在某些情况比较简单时,是否要使用工厂模式,需要权衡利弊了。
 


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
工厂方法模式是一种常见的创建型设计模式,它定义了一个用于创建对象的接口,但是由子类决定要实例化的类是哪一个。在工厂方法模式中,创建对象的过程被分离出来,使得这个过程可以被子类定制化,从而提高了代码的可扩展性和可维护性。 工厂方法模式的核心思想是将对象的创建和使用分离开来,客户端只需要知道所需对象的类型,而无需关心对象的创建过程。具体来说,工厂方法模式包含以下几个角色: 1. 抽象工厂(Abstract Factory):定义了工厂方法的接口,用于创建产品对象。 2. 具体工厂(Concrete Factory):实现抽象工厂接口,根据具体需求创建具体产品对象。 3. 抽象产品(Abstract Product):定义了产品的接口,用于描述产品的属性和行为。 4. 具体产品(Concrete Product):实现抽象产品接口,提供具体的实现。 使用工厂方法模式可以将客户端代码和具体产品的实现代码分离开来,使得代码更加灵活和可扩展。工厂方法模式在实际应用中也有很多场景,例如: 1. 当一个类不知道它所必须创建的对象的类的时候。 2. 当一个类希望由它的子类来指定所创建的对象的时候。 3. 当类将创建对象的职责委托给多个帮助子类中的某个特定子类,并且希望能够在运行时切换这些子类中的哪一个时。 总之,工厂方法模式是一种非常实用的设计模式,可以提高代码的可维护性和可扩展性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

peak wang

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

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

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

打赏作者

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

抵扣说明:

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

余额充值