设计模式-工厂模式

工厂模式

Java中常用的设计模式,工厂可以说为我们提供产品的服务,主要方便我们创建对象。

优点:灵活的控制生产过程,可扩展性高,在工厂中控制权限、添加日志、修饰。

1.简单工厂模式

1.创建一个抽象类或接口

java 复制代码
public interface Animal {
    public void eat();
}

2.创建具体类

java 复制代码
public class Cat implements Animal{
    @Override
    public void eat() {
        System.out.println("吃猫粮");
    }
}

public class Dog implements Animal{
    @Override
    public void eat() {
        System.out.println("吃狗粮");
    }
}

3.创建一个简单工厂类

java 复制代码
public class AnimalFactory {
    public Cat createCat(){
        return new Cat();
    }

    public Dog createDog(){
        return new Dog();
    }
}

3.工厂方法模式

1.创建一个抽象类或接口

java 复制代码
public interface Animal {
    public void eat();
}

2.创建具体类

java 复制代码
public class Cat implements Animal{
    @Override
    public void eat() {
        System.out.println("吃猫粮");
    }
}

public class Dog implements Animal{
    @Override
    public void eat() {
        System.out.println("吃狗粮");
    }
}

3.创建工厂类

java 复制代码
public class CatFactory {
    public Cat createCat(){
        return new Cat();
    }
}
public class DogFactory {
    public Dog createDog(){
        return new Dog();
    }
}

缺点:

类的数量增加:在工厂方法模式中,每个具体产品都对应一个具体工厂类。如果系统中存在大量的产品类型,就会导致产生大量的具体工厂类,增加了类的数量,使得系统更加复杂。

客户端需要知道具体工厂类:在工厂方法模式中,客户端需要直接使用具体工厂类来创建产品对象。这使得客户端与具体工厂类之间产生了耦合,违背了依赖倒置原则。

需要维护和管理工厂类:每个具体工厂类都需要负责创建对应的产品对象。如果有多个具体工厂类,就会增加维护和管理的复杂性。

3.抽象工厂模式

使用场景:当需要创建一组相关或相互依赖的产品对象时,可以使用抽象工厂模式。这些产品对象之间存在一定的逻辑关系,需要一起使用或者配合使用;当希望客户端与具体产品的实现解耦,只与抽象工厂和抽象产品进行交互时,可以使用抽象工厂模式。这样可以隐藏具体产品的实现细节,提供灵活的产品切换和扩展。

1.定义抽象产品

java 复制代码
public interface IFood {
    public void eat();
}
public interface IHand {
    public void take();
}

2.定义具体产品

java 复制代码
class Food extends AbstractFood{
    @Override
    public void eat() {
        System.out.println("吃猫粮");
    }
}
java 复制代码
public class Hand extends AbstracatHand{
    @Override
    public void take() {
        System.out.println("take ...");
    }
}

3.定义抽象工厂

java 复制代码
public abstract class ModelFactory {
    public abstract Food createFood();
    public abstract Hand createHand();
}

4.定义具体工厂

java 复制代码
public class Factory extends ModelFactory{
    @Override
    public Food createFood() {
        return new Food();
    }

    @Override
    public Hand createHand() {
        return new Hand();
    }
}
相关推荐
咖啡八杯19 小时前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
槑有老呆1 天前
从 Prompt Engineering 到 Harness Engineering:AI 编程的下一次跃迁
设计模式
HjhIron1 天前
从Prompt到Context:大模型应用开发的范式转移
设计模式·aigc·ai编程
咖啡八杯3 天前
GoF设计模式——中介者模式
java·后端·spring·设计模式
胡萝卜术3 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
亦暖筑序4 天前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
青禾网络6 天前
Web 前端如何接入 AI 音效生成:从零到可用的完整方案
人工智能·设计模式
ZJPRENO7 天前
吃透软件开发六大设计原则,告别烂代码
设计模式
咖啡八杯7 天前
GoF设计模式——命令模式
java·设计模式·架构
花椒技术8 天前
HJPusher / HJPlayer SDK 实践:我们为什么把直播推播链路拆成一套可复用能力
设计模式·harmonyos·直播