浅谈JAVA设计模式之——抽象工厂模式(AbstractFactoty)

简介: 提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。

一、概述:


提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类。


二、为何使用


工厂模式是我们最常用的模式了,著名的Jive论坛 ,就大量使用了工厂模式,工厂模式在Java程序系统可以说是随处可见。


为什么工厂模式是如此常用?因为工厂模式就相当于创建实例对象的new,我们经常要根据类Class生成实例对象,如A a=new A() 工厂模式也是用来创建实例对象的,所以以后new时就要多个心眼,是否可以考虑实用工厂模式,虽然这样做,可能多做一些工作,但会给你系统带来更大的可扩展性和尽量少的修改量


三、实用性


  • 一个系统要独立于它的产品的创建、组合和表示时。
  • 一个系统要由多个产品系列中的一个来配置时。
  • 当你要强调一系列相关的产品对象的设计以便进行联合使用时。
  • 当你提供一个产品类库,而只想显示它们的接口而不是实现时。


四、参与者


  • AbstractFactory 声明一个创建抽象产品对象的操作接口。
  • ConcreteFactory 实现创建具体产品对象的操作。
  • AbstractProduct 为一类产品对象声明一个接口。
  • ConcreteProduct 定义一个将被相应的具体工厂创建的产品对象。实现AbstractProduct接口。
  • Client 仅使用由AbstractFactory和AbstractProduct类声明的接口


五、类图


ss.jpg

六、示例


AbstractFactory:定义抽象工程类IAnimalFactory


package com.lyz.design.abstractfactory;
/**
 * 这个接口就是类图中标识的
 * AbstractFactory抽象工厂
 * @author liuyazhuang
 *
 */
public interface IAnimalFactory {
    /**
     * 定义创建Icat接口实例的方法
     * @return
     */
    ICat createCat();
    /**
     * 定义创建IDog接口实例的方法
     * @return
     */
    IDog createDog();
}


ConcreteFactory创建抽象工厂类的两个实现类,WhiteAnimalFactory和BlackAnimalFactory



package com.lyz.design.abstractfactory;
/**
 * IAnimalFactory抽象工厂的实现类
 * @author liuyazhuang
 *
 */
public class WhiteAnimalFactory implements IAnimalFactory {
    public ICat createCat() {
        return new WhiteCat();
    }
    public IDog createDog() {
        return new WhiteDog();
    }
}


package com.lyz.design.abstractfactory;
/**
 * IAnimalFactory抽象工厂的实现类
 * @author liuyazhuang
 */
public class BlackAnimalFactory implements IAnimalFactory {
  @Override
    public ICat createCat() {
        return new BlackCat();
    }
    public IDog createDog() {
        return new BlackDog();
    }
}


AbstractProduct定义抽象工厂中要生产的抽象产品接口ICat和IDog


package com.lyz.design.abstractfactory;
/**
 * 类图中定义的AbstractProduct
 * 指定工厂生产的产品
 * @author liuyazhuang
 *
 */
public interface ICat {
    /**
     * 定义方法
     */
    void eat();
}



package com.lyz.design.abstractfactory;
/**
 * 类图中定义的AbstractProduct
 * 指定工厂生产的产品
 * @author liuyazhuang
 *
 */
public interface IDog {
   /**
     * 定义方法
     */
    void eat();
}


ConcreteProduct创建产品的实现类BlackCat、BlackDog、WhiteCat、WhiteDog


package com.lyz.design.abstractfactory;
/**
 * ICat接口的实现类
 * @author liuyazhuang
 *
 */
public class BlackCat implements ICat {
  @Override
    public void eat() {
        System.out.println("The black cat is eating!");
    }
}



package com.lyz.design.abstractfactory;
/**
 * IDog的实现类
 * @author liuyazhuang
 */
public class BlackDog implements IDog {
  @Override
    public void eat() {
        System.out.println("The black dog is eating");
    }
}



package com.lyz.design.abstractfactory;
/**
 * ICat的实现类
 * @author liuyazhuang
 *
 */
public class WhiteCat implements ICat {
  @Override
    public void eat() {
        System.out.println("The white cat is eating!");
    }
}


package com.lyz.design.abstractfactory;
/**
 * IDog的实现类
 * @author liuyazhuang
 *
 */
public class WhiteDog implements IDog {
  @Override
    public void eat() {
        System.out.println("The white dog is eating!");
    }
}


Client:定义一个测试类Test


package com.lyz.design.abstractfactory;
/**
 * 测试类
 * @author liuyazhuang
 *
 */
public class Test {
  public static void main(String[] args) {
      IAnimalFactory blackAnimalFactory = new BlackAnimalFactory();
      ICat blackCat = blackAnimalFactory.createCat();
      blackCat.eat();
      IDog blackDog = blackAnimalFactory.createDog();
      blackDog.eat();
      IAnimalFactory whiteAnimalFactory = new WhiteAnimalFactory();
      ICat whiteCat = whiteAnimalFactory.createCat();
      whiteCat.eat();
      IDog whiteDog = whiteAnimalFactory.createDog();
      whiteDog.eat();
  }
}


输出结果



The black cat is eating!
The black dog is eating
The white cat is eating!
The white dog is eating!


七、总结


由此可见,工厂方法确实为系统结构提供了非常灵活强大的动态扩展机制,只要我们更换一下具体的工厂方法,系统其他地方无需一点变换,就有可能将系统功能进行改头换面的变化

相关文章
|
24天前
|
设计模式 Java Spring
Java 设计模式之责任链模式:优雅处理请求的艺术
责任链模式通过构建处理者链,使请求沿链传递直至被处理,实现发送者与接收者的解耦。适用于审批流程、日志处理等多级处理场景,提升系统灵活性与可扩展性。
176 2
|
24天前
|
设计模式 网络协议 数据可视化
Java 设计模式之状态模式:让对象的行为随状态优雅变化
状态模式通过封装对象的状态,使行为随状态变化而改变。以订单为例,将待支付、已支付等状态独立成类,消除冗长条件判断,提升代码可维护性与扩展性,适用于状态多、转换复杂的场景。
217 0
|
3月前
|
设计模式 缓存 Java
Java设计模式(二):观察者模式与装饰器模式
本文深入讲解观察者模式与装饰器模式的核心概念及实现方式,涵盖从基础理论到实战应用的全面内容。观察者模式实现对象间松耦合通信,适用于事件通知机制;装饰器模式通过组合方式动态扩展对象功能,避免子类爆炸。文章通过Java示例展示两者在GUI、IO流、Web中间件等场景的应用,并提供常见陷阱与面试高频问题解析,助你写出灵活、可维护的代码。
|
23天前
|
设计模式 算法 搜索推荐
Java 设计模式之策略模式:灵活切换算法的艺术
策略模式通过封装不同算法并实现灵活切换,将算法与使用解耦。以支付为例,微信、支付宝等支付方式作为独立策略,购物车根据选择调用对应支付逻辑,提升代码可维护性与扩展性,避免冗长条件判断,符合开闭原则。
219 35
|
23天前
|
设计模式 消息中间件 传感器
Java 设计模式之观察者模式:构建松耦合的事件响应系统
观察者模式是Java中常用的行为型设计模式,用于构建松耦合的事件响应系统。当一个对象状态改变时,所有依赖它的观察者将自动收到通知并更新。该模式通过抽象耦合实现发布-订阅机制,广泛应用于GUI事件处理、消息通知、数据监控等场景,具有良好的可扩展性和维护性。
191 8
|
6月前
|
设计模式 Java 关系型数据库
【设计模式】【创建型模式】抽象工厂模式(Abstract Factory)
一、入门 什么是抽象工厂模式? 抽象工厂模式是一种创建型设计模式,它提供了一个接口,用于创建相关或依赖对象的家族,而不需要指定具体的类。 简单来说,抽象工厂模式是工厂方法模式的升级版,它能够创建一组相
230 14
|
6月前
|
设计模式 缓存 安全
【高薪程序员必看】万字长文拆解Java并发编程!(8):设计模式-享元模式设计指南
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发编程中的经典对象复用设计模式-享元模式,废话不多说让我们直接开始。
153 0
|
3月前
|
设计模式 安全 Java
Java设计模式(一):单例模式与工厂模式
本文详解单例模式与工厂模式的核心实现及应用,涵盖饿汉式、懒汉式、双重检查锁、工厂方法、抽象工厂等设计模式,并结合数据库连接池与支付系统实战案例,助你掌握设计模式精髓,提升代码专业性与可维护性。
|
3月前
|
设计模式 XML 安全
Java枚举(Enum)与设计模式应用
Java枚举不仅是类型安全的常量,还具备面向对象能力,可添加属性与方法,实现接口。通过枚举能优雅实现单例、策略、状态等设计模式,具备线程安全、序列化安全等特性,是编写高效、安全代码的利器。
|
8月前
|
设计模式 Java 数据安全/隐私保护
Java 设计模式:装饰者模式(Decorator Pattern)
装饰者模式属于结构型设计模式,允许通过动态包装对象的方式为对象添加新功能,提供比继承更灵活的扩展方式。该模式通过组合替代继承,遵循开闭原则(对扩展开放,对修改关闭)。