Java 抽象工厂模式

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

抽象产品类:

public abstract class Product {
    /**
     * 公共方法
     */
    public void common() {
        System.out.println("公共方法");
    }

    public abstract void detail();
}

产品实现类:

public class Car extends Product {
    @Override
    public void detail() {
        System.out.println("汽车");
    }
}
public class Plane extends Product {

    @Override
    public void detail() {
        System.out.println("飞机");
    }
}

抽象工厂接口:

public interface Creator {
    Product createCar();

    Product createPlane();

}

抽象工厂实现类:

public class CreatorImpl implements Creator {
    @Override
    public Product createCar() {
        return new Car();
    }

    @Override
    public Product createPlane() {
        return new Plane();
    }
}

测试示例:

public class Example {
    public static void main(String[] args) {
        Creator creator = new CreatorImpl();
        Product product = creator.createCar();
        product.detail();
        product = creator.createPlane();
        product.detail();
        product.common();
    }
}
### 回答1: Java抽象工厂模式(Abstract Factory Pattern)是一种创建型设计模式,它提供了一种将一组相关的工厂组合起来创建对象的方式,而不必指定具体的类。 抽象工厂模式通常涉及一个抽象工厂类,它声明了用于创建一组相关对象的抽象方法。每个具体的工厂类都实现了这些抽象方法,以便创建一组特定的对象。这些具体的工厂类通常在运行时通过依赖注入或配置文件等方式被选择和实例化。 在抽象工厂模式中,客户端代码只与抽象工厂类和抽象产品类交互。这使得客户端代码能够与特定实现细节分离,从而更加灵活和可维护。 以下是Java抽象工厂模式的简单示例: ```java // 抽象工厂类 public interface AbstractFactory { public ProductA createProductA(); public ProductB createProductB(); } // 具体工厂类 1 public class ConcreteFactory1 implements AbstractFactory { public ProductA createProductA() { return new ConcreteProductA1(); } public ProductB createProductB() { return new ConcreteProductB1(); } } // 具体工厂类 2 public class ConcreteFactory2 implements AbstractFactory { public ProductA createProductA() { return new ConcreteProductA2(); } public ProductB createProductB() { return new ConcreteProductB2(); } } // 抽象产品类 public interface ProductA { public void methodA(); } // 具体产品类 1 public class ConcreteProductA1 implements ProductA { public void methodA() { System.out.println("ConcreteProductA1's methodA"); } } // 具体产品类 2 public class ConcreteProductA2 implements ProductA { public void methodA() { System.out.println("ConcreteProductA2's methodA"); } } // 抽象产品类 public interface ProductB { public void methodB(); } // 具体产品类 1 public class ConcreteProductB1 implements ProductB { public void methodB() { System.out.println("ConcreteProductB1's methodB"); } } // 具体产品类 2 public class ConcreteProductB2 implements ProductB { public void methodB() { System.out.println("ConcreteProductB2's methodB"); } } ``` 在这个示例中,抽象工厂类(AbstractFactory)声明了创建ProductA和ProductB的抽象方法。具体工厂类1(ConcreteFactory1)和具体工厂类2(ConcreteFactory2)都实现了这些方法,以便分别创建ConcreteProductA1和ConcreteProductB1或ConcreteProductA2和ConcreteProductB2等具体产品类的实例。这些具体工厂类可以通过依赖注入或配置文件等方式被选择和实例化。 客户端代码只需要通过抽象工厂类来创建ProductA和ProductB的实例,无需关心 ### 回答2: 抽象工厂模式是一种创建型设计模式,它提供了一种将相关的对象组织起来创建的方法。在Java中,抽象工厂模式由抽象工厂和具体工厂、抽象产品和具体产品组成。 抽象工厂是一个接口或抽象类,它声明了一组创建产品的方法,这些方法可以返回抽象产品或产品族。具体工厂实现了抽象工厂接口,并实现了具体的产品创建方法。 抽象产品定义了产品的通用特性和行为,而具体产品则继承或实现了抽象产品,并提供了具体的实现。 通过使用抽象工厂模式,我们可以轻松地添加或替换整个产品族,而无需修改客户端代码。客户端只需要通过抽象工厂接口来创建产品,而不需要关心具体的产品或产品族。 以下是使用Java实现抽象工厂模式的一个简单示例: ``` // 抽象产品A interface ProductA { void operationA(); } // 抽象产品B interface ProductB { void operationB(); } // 具体产品A1 class ConcreteProductA1 implements ProductA { @Override public void operationA() { System.out.println("ConcreteProductA1 operationA"); } } // 具体产品A2 class ConcreteProductA2 implements ProductA { @Override public void operationA() { System.out.println("ConcreteProductA2 operationA"); } } // 具体产品B1 class ConcreteProductB1 implements ProductB { @Override public void operationB() { System.out.println("ConcreteProductB1 operationB"); } } // 具体产品B2 class ConcreteProductB2 implements ProductB { @Override public void operationB() { System.out.println("ConcreteProductB2 operationB"); } } // 抽象工厂 interface AbstractFactory { ProductA createProductA(); ProductB createProductB(); } // 具体工厂1 class ConcreteFactory1 implements AbstractFactory { @Override public ProductA createProductA() { return new ConcreteProductA1(); } @Override public ProductB createProductB() { return new ConcreteProductB1(); } } // 具体工厂2 class ConcreteFactory2 implements AbstractFactory { @Override public ProductA createProductA() { return new ConcreteProductA2(); } @Override public ProductB createProductB() { return new ConcreteProductB2(); } } // 客户端代码 public class Client { public static void main(String[] args) { AbstractFactory factory = new ConcreteFactory1(); ProductA productA = factory.createProductA(); ProductB productB = factory.createProductB(); productA.operationA(); productB.operationB(); } } ``` 以上示例中,抽象工厂`AbstractFactory`定义了创建产品A和B的抽象方法。具体工厂`ConcreteFactory1`和`ConcreteFactory2`分别实现了抽象工厂接口,负责创建具体的产品A和B。具体的产品A和B都实现了对应的接口。在客户端代码中,我们可以通过切换具体工厂来创建不同的产品族,而无需修改客户端代码。 ### 回答3: 抽象工厂模式是一种创建型设计模式,它提供了一个抽象的工厂接口,用于创建一系列相关或依赖的对象,而无需指定其具体的类。通过使用该模式,我们可以将对象的创建和使用分离开来,提供更好的灵活性和可扩展性。 在Java中,抽象工厂模式通常由一个抽象工厂接口和多个具体工厂类来实现。抽象工厂接口定义了创建一系列产品对象的方法,而具体工厂类分别实现这些方法来创建具体的产品对象。 抽象工厂模式适用于需要创建一系列相关的产品对象的场景,例如创建不同类型的按钮和文本框组合。我们可以定义一个抽象按钮工厂接口和一个抽象文本框工厂接口,然后分别由多个具体按钮工厂类和文本框工厂类来实现这些接口。这样一来,当需要创建不同类型的按钮和文本框时,只需通过对应的工厂对象调用相应的方法即可,不需要关心具体的实现。 抽象工厂模式的优点是能够在不修改客户端代码的情况下引入新的产品系列,与客户端代码解耦。同时,它也能够保证所创建的对象是一致相关的,符合一定的规范。 然而,抽象工厂模式也存在一些缺点。由于每增加一个产品系列,就需要增加一个对应的具体工厂类,这样会使得系统的类的个数增加。同时,如果需要扩展产品对象的种类,就需要修改抽象工厂接口以及所有具体工厂类的实现,这样会对系统的扩展性造成一定的影响。 总的来说,抽象工厂模式在某些特定的场景下能够提供一种简便、灵活的对象创建方式,但同时也需要权衡其对系统复杂性和可扩展性的影响。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值