Java设计模式——抽象工厂模式

假设一家4s店卖宝马和大众两种汽车,并且车种分为轿车和卡车两种,像这种工厂产品来自多个等级结构的,简单工厂和工厂方法难以实现需求,这时我们可以使用抽象工厂来实现。

 下面看一下代码的简单实现;

1,先定义轿车和卡车的接口

//轿车
public interface Sedan {

    public void run();

}


//卡车
public interface Truck {

    public void run();

}

2,创建类分别去实现宝马和大众的轿车和卡车

public class BmwSedan implements Sedan{
    @Override
    public void run() {
        System.out.println("喜提宝马轿车!");
    }
}


public class BmwTruck implements Truck{
    @Override
    public void run() {
        System.out.println("喜提宝马卡车!");
    }
}


public class DaZSedan implements Sedan{
    @Override
    public void run() {
        System.out.println("喜提大众轿车!");
    }
}


public class DaZTruck  implements Truck{
    @Override
    public void run() {
        System.out.println("喜提大众卡车!");
    }
}

3,定义一个生产车的工厂

public interface CarFactory {

    public Truck productTruck();

    public Sedan productSedan();

}

4,分别实现宝马和大众的工厂

public class BmwFactory implements CarFactory{

    @Override
    public Truck productTruck() {
        return new BmwTruck();
    }

    @Override
    public Sedan productSedan() {
        return new BmwSedan();
    }
}



public class DaZFactory implements CarFactory{
    @Override
    public Truck productTruck() {
        return new DaZTruck();
    }

    @Override
    public Sedan productSedan() {
        return new DaZSedan();
    }
}

5,模拟客户买不同的车

public class Customer {
    public static void main(String args[]){
        CarFactory bf = new BmwFactory();
        bf.productSedan().run();
        bf.productTruck().run();

        CarFactory df = new DaZFactory();
        df.productSedan().run();
        df.productTruck().run();
    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值