设计模式-抽象工厂模式

本文介绍了抽象工厂模式,它为创建相关或依赖对象提供接口,无需指定具体类。通过一个小例子展示了其使用,包括接口、实现类等。还指出它是工厂方法模式的升级,适用于多业务品种分类。同时阐述了其优点是有封装性、产品族非公开,缺点是产品族扩展困难。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • Provide an interface for creating families of related or dependent objects without specifying their concrete classes.(为创建一组相关或相互依赖的对象提供一个接口,而且无须指定它们的具体类。)

  • 通用类图

image.png

先举一个抽象工厂的小例子,具体怎么用了解下

接口

//创建接口
public interface Car {
    //每个车都有颜色
    public void getColor();

    //每个车都有轮胎颜色
    public void getTire();

        //发动机
    public void engine();
}

接口抽象类

//接口抽象类
public abstract class AbstractAudiWhiteCar implements Car {
    //黑色奥迪车
    public void getColor(){
        System.out.println("白色奥迪车");
    }

    //黑色轮胎
    public void getTire(){
        System.out.println("白色轮胎");
    }

}
//接口抽象类
public abstract class AbstractAudiRedCar implements Car {
    //黑色奥迪车
    public void getColor(){
        System.out.println("红色奥迪车");
    }

    //黑色轮胎
    public void getTire(){
        System.out.println("红色轮胎");
    }

}

//接口抽象类
public abstract class AbstractAudiBlackCar implements Car {
    //黑色奥迪车
    public void getColor(){
        System.out.println("黑色奥迪车");
    }

    //黑色轮胎
    public void getTire(){
        System.out.println("黑色轮胎");
    }

}

接口实现类

//接口实现类
public class V6AudiBlackCar extends AbstractAudiBlackCar {
    @Override
    public void engine() {
        System.out.println("发动机是v6");
    }
}
//接口实现类
public class V6AudiRedCar extends AbstractAudiRedCar {
    @Override
    public void engine() {
        System.out.println("发动机是v6");
    }
}
//接口实现类
public class V6AudiWhiteCar extends AbstractAudiWhiteCar {
    @Override
    public void engine() {
        System.out.println("发动机是v6");
    }
}

//接口实现类
public class V12AudiBlackCar extends AbstractAudiBlackCar {
    @Override
    public void engine() {
        System.out.println("发动机是v12");
    }
}
//接口实现类
public class V12AudiRedCar extends AbstractAudiRedCar {
    @Override
    public void engine() {
        System.out.println("发动机是v12");
    }
}

//接口实现类
public class V12AudiWhiteCar extends AbstractAudiWhiteCar {
    @Override
    public void engine() {
        System.out.println("发动机是v12");
    }
}

//接口实现类
public class V6AudiBlackCar extends AbstractAudiBlackCar {
    @Override
    public void engine() {
        System.out.println("发动机是v6");
    }
}

生产车的工厂

public interface CarFactory {
    //黑色车
    public Car createAudiBlackCar();
    //红色车
    public Car createAudiRedCar();
    //白色车
    public Car createAudiWhiteCar();
}

生产v6车的工厂

public class V6Factory implements CarFactory {
    @Override
    public Car createAudiBlackCar() {
        return new V6AudiBlackCar();
    }

    @Override
    public Car createAudiRedCar() {
        return new V6AudiRedCar();
    }

    @Override
    public Car createAudiWhiteCar() {
        return new V6AudiWhiteCar();
    }
}

生产v12车工厂

public class V12Factory implements CarFactory {
    @Override
    public Car createAudiBlackCar() {
        return new V12AudiBlackCar();
    }

    @Override
    public Car createAudiRedCar() {
        return new V12AudiRedCar();
    }

    @Override
    public Car createAudiWhiteCar() {
        return new V12AudiWhiteCar();
    }
}

客户端调用

public class Client {
    public static void main(String[] args) {
        //生产v6发动机 黑色车
        CarFactory carFactory = new V6Factory();
        Car audiBlackCar = carFactory.createAudiBlackCar();
        audiBlackCar.engine();
        audiBlackCar.getColor();
        audiBlackCar.getTire();
        //生产v12发动机 红色车
        CarFactory carFactory1 = new V12Factory();
        Car audiRedCar = carFactory1.createAudiRedCar();
        audiRedCar.getTire();
        audiRedCar.getColor();
        audiRedCar.engine();
    }
}

下面是运行结果

 

image.png

  • 注意:抽象工厂模式是工厂方法模式的升级版本,在有多个业务品种、业务分类时,通过抽象工厂模式产生需要的对象是一种非常好的解决方式

  • 抽象工厂的优点

1.具有一定的封装性,每个产品实现类不是高层模块要关心的。
2.产品族里面为非公开状态。具体意思就是,我生产一个红颜色的车,可以生产两个黑颜色的车,这样的生产过程对调用工厂类高层模块是透明的。

  • 抽象工厂的缺点

最大的缺点就是产品族扩展困难,比如我要在新增一个绿颜色的车。抽象类AbstractCreator要增加一个方法createProductC(),然后两个实现类都要修改。

以上就是抽象工厂模式的基本简单用法,欢迎大家查看并指出不足的地方,万分感谢

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

境里婆娑

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

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

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

打赏作者

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

抵扣说明:

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

余额充值