java中的抽象工厂模式

设计模式之抽象工厂模式(FactoryMethod Pattern)

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

工厂方法的实现主要是通过以下步骤

  1. 创建一个或多个抽像工厂(代码里面为链接和发送),里面定义一个抽象方法;
  2. 创建工具类接口提供选择(里面有第一步的两个方法),到此规则定义完成
  3. 创建MySQL(Oracle)产品实现链接的接口,实现上级接口方法
  4. 创建工具类MySQL(Oracle)实例,实现上级的两个方法

适用场景:

工作了,为了参加一些聚会,肯定有两套或多套衣服吧,比如说有商务装(成套,一系列具体产品)、时尚装(成套,一系列具体产品),甚至对于一个家庭来说,可能有商务女装、商务男装、时尚女装、时尚男装,这些也都是成套的,即一系列具体产品。假设一种情况(现实中是不存在的,要不然,没法进入共产主义了,但有利于说明抽象工厂模式),在您的家中,某一个衣柜(具体工厂)只能存放某一种这样的衣服(成套,一系列具体产品),每次拿这种成套的衣服时也自然要从这个衣柜中取出了。用 OO 的思想去理解,所有的衣柜(具体工厂)都是衣柜类的(抽象工厂)某一个,而每一件成套的衣服又包括具体的上衣(某一具体产品),裤子(某一具体产品),这些具体的上衣其实也都是上衣(抽象产品),具体的裤子也都是裤子(另一个抽象产品)。

优点

  • 当一个产品族中的多个对象被设计成一起工作时,它能保证客户端始终只使用同一个产品族中的对象。

缺点

  • 产品族扩展非常困难,要增加一个系列的某一产品,既要在抽象的 Creator 里加代码,又要在具体的里面加代码。

    实现的方式
/**
 * 抽象工厂模式
 * 模拟数据库的链接选择
 * @author :高铭
 * @date :Created in 2020/10/10 17:22
 */
public class AbstractFactoryPattern {
    public static void main(String[] args) {
//        DateBaseUtils dateBaseUtils = new mysqlDateBaseUtil();
        DateBaseUtils dateBaseUtils = new oracleDateBaseUtil();
        Iconnection connect = dateBaseUtils.getConnect();
        connect.connect();
        Icommand command = dateBaseUtils.getCommand();
        command.command();
    }
}

/**
 * 打开链接
 */
interface Iconnection{
      void connect();
}

/**
 * 发送sql
 */
interface Icommand{
    void command();
}

/**
 * 选择工具类
 */
interface DateBaseUtils{
    Iconnection getConnect();
    Icommand getCommand();
}

/**
 * 创建mysql链接
 */
class mysqlConnection implements Iconnection{

    @Override
    public void connect() {
        System.out.println("mysql创建链接");
    }
}

/**
 * 创建mysql发送
 */
class mysqlCommand implements Icommand{

    @Override
    public void command() {
        System.out.println("mysql发送sql");
    }
}
/**
 * 创建oracle链接
 */
class oracleConnection implements Iconnection{

    @Override
    public void connect() {
        System.out.println("oracle创建链接");
    }
}
/**
 * oracle发送sql
 */
class oracleCommand implements Icommand{

    @Override
    public void command() {
        System.out.println("oracle发送了sql");
    }
}
/**
 * 选择mysql工具
 */
class mysqlDateBaseUtil implements DateBaseUtils{
    @Override
    public Iconnection getConnect() {
        return new mysqlConnection();
    }

    @Override
    public Icommand getCommand() {
        return new mysqlCommand();
    }
}

/**
 * 选择oracle工具
 */
class oracleDateBaseUtil implements DateBaseUtils{
    @Override
    public Iconnection getConnect() {
        return new oracleConnection();
    }

    @Override
    public Icommand getCommand() {
        return new oracleCommand();
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值