java设计模式之工厂系列----Factory_Series_DesignPattern

距离上次写设计模式的博客已经很久,翻看一下,是【java设计模式之责任链----Filter (2015-06-15 22:59)】时间好长了啊。

按理说,应该两天一片的速度,哎,都是我太懒了,眼高手低的,而且还有点。。。所以应该要想我的座右铭一样【专心致志做好一件事】,好好做事,认真做人。

不闲扯了,现在开始正题:

同样,这一片的工厂系列的设计模式依旧是学习了马老师的设计模式总结来写的。听马老师的课感觉倍舒服,无拘无束,虽然还是会过后就忘了,嘻嘻^^!

由于马老师的课程安排深浅得很合理,我就不自己瞎吵吵了,按照课程的安排来。

step1 -- 围绕交通工具展开课程,如图

step2 -- 【静态工厂模式】如何控制司机只开一辆车而且车的产生不是司机来控制的?

静态工厂模式:

public class Car {

    private static Car car = new Car();
//    private static List<Car> cars = new ArrayList<Car>();
    private Car(){

    }
    public static Car getInstance(){
        return car;
    }

    public void run(){
        System.out.println("我开车了。。。");
    }
}

将构造方法私有化,在类的外部就不能通过直接new来获取对象了。如果不将getInstance声明为static,那么久不能在外部直接调用该方法。如果在该方法中直接返回【new Car()】,那么我开的车就不是一个车了,每次调用这个方法获得的都是新Car。加上【private static Car car = new Car();】就将Car的对象进行固定了,这样就只能开一辆,别人获得的也是同一辆车,意思就是在整个环境中就只有这么一个Car,这就是单例模式。

step3 -- 【简单工厂模式】如何任意定制交通工具的类型和生产过程

为了实现可以对交通工具的任意定制,此时面向对象的java的优势就出来了,她的封装、继承和多态的特点就show了。具体怎么实现呢?

既然都是交通工具,都会移动,那么我以定义一个接口【Moveable】,

public interface Moveable {
    void run();
}

在调用具体的交通工具时就是面向接口编程,但前提是这些交通工具都要实现这个接口。如下代码:

public class Test {
    public static void main(String[] args) {
        Moveable m = new Car();
        m.run();
    }
}

其中的Car实现了那个Moveable接口。

那么怎么控制这些个交通工具的生产过程呢?比如,如何控制是否有足够权限来生产这类交通工具。

这肯定就要用工厂了啊,工厂就是生产产品,生产交通工具的啊,权限就像是你给工厂下的订单,工厂不能相信你,工厂也不敢给你做。

那么具体实现是什么呢?

给每一个实现了【Moveable】接口的类,都专门“建立”一个工厂,专门来生产对应得产品。

为了,使这些工厂能有同统一的方法来产生对象,也就是为了以后的扩展性更好,需求发生改变时修改的地方最少,那么就给这些工厂升华出一个父类或者是接口都OK!这里就来个抽象类【VehicleFactory】

看代码:

public abstract class VehicleFactory {
    abstract Moveable create();
}
---------------------------
public class CarFactory extends VehicleFactory{
    public Moveable create() {
        return new Car();
    }
}
---------------------------
public class Test {
    public static void main(String[] args) {
        VehicleFactory factory = new BroomFactory();
        Moveable m = factory.create();
        m.run();
    }
}

step4 -- 【抽象工厂模式】系列产品的生产,如果还是用简单工厂模式的话,那么要改的话必然会早成很多地方要改,而且扩展也不方便,因为这一系列的产品工厂都得重“建立”,那么怎样才能省,才能方便呢?

思路就是,有一个工厂可以生产一系列的产品,而不是只生产一类产品。好了,思路出来了代码上:

public abstract class AbstractFactory {
    public abstract Vehicle createVehicle();
    public abstract Weapon createWeapon();
    public abstract Food createFood();
}
------------------------
public abstract class Vehicle {
    public abstract void run();
}
-----------------------
public abstract class Weapon {
    public abstract void shoot();
}
-------------------------
public abstract class Food {
    public abstract void printName();
}
-------------------------
public class AK47 extends Weapon{
    public void shoot() {
        System.out.println("哒哒哒...");
    }
}
-------------------------
public class Apple extends Food {
    public void printName() {
        System.out.println("apple");
    }
}
-----------------------
public class Car extends Vehicle {
    public void run() {
        System.out.println("冒着烟奔跑中car.......");
    }
}
-----------------------
public class DefaultFactory extends AbstractFactory{

    @Override
    public Food createFood() {
        return new Apple();
    }

    @Override
    public Vehicle createVehicle() {
        return new Car();
    }

    @Override
    public Weapon createWeapon() {
        return new AK47();
    }

}
------------------------------
public class MagicFactory extends AbstractFactory {

    @Override
    public Food createFood() {
        return new MushRoom();
    }

    @Override
    public Vehicle createVehicle() {
        return new Broom();
    }

    @Override
    public Weapon createWeapon() {
        return new MagicStick();
    }

}

这样当要替换这一系列的产品的时候,只需要更换具体的工厂就OK了。如下代码:

public class Test {
    public static void main(String[] args) {
        AbstractFactory f = new DefaultFactory();
        Vehicle v = f.createVehicle();
        v.run();
        Weapon w = f.createWeapon();
        w.shoot();
        Food a = f.createFood();
        a.printName();
    }
}

step6 -- Spring的IoC和AOP

Spring的IoC就是很专业的面向接口的编程。在她的配置文件里声明了接口的具体实现类。在这里就不细说她的工作原理了。

finally -- 最后就说一下,简单工厂和抽象工厂的区别,其实就是灵活度和方便度的不同,简单的灵活,但是抽象的方便。

马老师说的很经典:【现在学模式,使为了用,当遇到问题,怎么合理怎么来,管他什么模式。要练就的就是“先是看山是山,到看山不是山,再到看山又是山”,学模式一样,多动手敲代码比什么都强!!!】

与看到此文的你,共勉!!!

时间: 2024-08-02 05:21:53

java设计模式之工厂系列----Factory_Series_DesignPattern的相关文章

Java设计模式(十) 备忘录模式 状态模式

(十九)备忘录模式 备忘录模式目的是保存一个对象的某个状态,在适当的时候恢复这个对象. class Memento{ private String value; public Memento(String value){ this.value = value; } public String getValue() { return value; } public void setValue(String value) { this.value = value; } } class Storage

Java设计模式(二)-单例模式

单例模式建议保证某个对象仅仅只有一个实例,当只有一个对象来协调整个系统的操作时,在计算机系统中,线程池.缓存.日志对象.对话框.打印机.显卡的驱动程序对象常被设计成单例,总之,选择单例模式就是为了避免不一致状态,避免政出多头. 下面是单例模式的类图:包括的private和static修饰的实例instance.一个private的构造函数.一个static的getInstance函数 单例模式主要有三种:懒汉式单例.饿汉式单例.登记式单例三种 1.饿汉式单例:在类的初始化时候,自行创建了实例 c

JAVA设计模式之 装饰模式【Decorator Pattern】

一.概述 动态地给一个对象增加一些额外的职责,就增加对象功能来说,装饰模式比生成子类实现更为灵活.装饰模式是一种对象结构型模式.装饰模式是一种用于替代继承的技术,使用对象之间的关联关系取代类之间的继承关系.在装饰模式中引入了装饰类,在装饰类中既可以调用待装饰的原有类的方法,还可以增加新的方法,以扩充原有类的功能. 二.适用场景 装饰原有对象.在不改变原有对象的情况下扩展增强新功能/新特征..当不能采用继承的方式对系统进行扩展或者采用继承不利于系统扩展和维护时可以使用装饰模式. 三.UML类图 四

(九)JAVA设计模式之单例模式

JAVA设计模式之单例模式 一.单例模式的介绍 Singleton是一种创建型模式,指某个类采用Singleton模式,则在这个类被创建后,只可能产生一个实例供外部访问,并且提供一个全局的访问点.     全局对象和Singleton模式有本质的区别,因为大量使用全局对象会使得程序质量降低,而且有些编程语言根本不支持全局变量.最重要的是传统的全局对象并不能阻止一个类被实例化多次. 二.单例模式的特点 单例类只能有一个实例 单例类必须自己创建自己的唯一实例. 单例类必须给所有其他对象提供这一实例.

JAVA设计模式有感

记得在大学学JAVA那阵,就觉得JAVA是一个c语言的一个包装,各种封装好的类库.功能,学习JAVA能快速上手编码.时隔8年,我感觉自己不懂JAVA. 最近看了有1个月的设计模式了,进度比较缓慢,一共才看了4个"策略模式","观察者模式","装饰者模式","工厂模式".也谈一谈自己的感受.其实这些设计模式以前也看过,当时的水准也就是硬生生记下了每个设计模式是怎么运作的,从没有想过它遵循了什么原则,达到了什么目的.因此,看过一遍

学习Java设计模式的10条建议

设计模式在整个Java的学习路线图中扮演着承上启下的作用. 在整个软件生命周期中,唯一不变的就是变化.设计模式就是要在软件设计.编码中对现有问题的一种总结,并从中寻求应对变化的策略. 自己初次接触设计模式有以下几个感觉: 内容很抽象. 示例都能看得懂,但不知道实际中如何应用. 不理解为什么要把“好好的程序”设计成这么复杂? 转眼之间到了需要自己参与需求分析.设计,并且维护之前留下的遗产代码(Legacy Code)的时候了. 再次开始学习设计模式,有了新的收获: 站在变化的角度去看,设计模式虽然

Java设计模式(五)外观模式 桥梁模式

(九)外观模式 外观模式为子系统提供一个接口,便于使用.解决了类与类之间关系的,外观模式将类之间的关系放在一个 Facade 类中,降低了类类之间的耦合度,该模式不涉及接口. class CPU { public void startup(){ System.out.println("cpu start"); } public void shutdown(){ System.out.println("cpu stop"); } } class Memory { pu

Java设计模式(六)合成模式 享元模式

(十一)合成模式 Composite 合成模式是一组对象的组合,这些对象可以是容器对象,也可以是单对象.组对象允许包含单对象,也可以包含其他组对象,要为组合对象和单对象定义共同的行为.合成模式的意义是 保证客户端调用单对象与组合对象的一致性. class TreeNode{ private String name; private TreeNode parent; private Vector<TreeNode> children = new Vector<TreeNode>();

Java设计模式之认识阶段

设计模式是什么? 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结. 其本质就是继承与接口的组合应用. 为什么要用设计模? 使用设计模式是为了可重用代码.让代码更容易被他人理解.保证代码可靠性.提高工作效率. 设计模式的分类: 设计模式按目的可分为三种类型,共23种. 创建型模式:单例模式.抽象工厂模式.建造者模式.工厂模式.原型模式. 结构型模式:适配器模式.桥接模式.装饰模式.组合模式.外观模式.享元模式.代理模式. 行为型模式:模版