JAVA设计模式--抽象工厂模式

抽象工厂设计模式

1.系统中有多个产品族,而系统一次只可能消费其中一族产品
2.同属于同一个产品族的产品以其使用。
来看看抽象工厂模式的各个角色(和工厂方法的如出一辙):
抽象工厂角色: 这是工厂方法模式的核心,它与应用程序无关。是具体工厂角色必须实现的接口或者必须继承的父类。在java中它由抽象类或者接口来实现。
具体工厂角色:它含有和具体业务逻辑有关的代码。由应用程序调用以创建对应的具体产品的对象。在java中它由具体的类来实现。
抽象产品角色:它是具体产品继承的父类或者是实现的接口。在java中一般有抽象类或者接口来实现。
具体产品角色:具体工厂角色所创建的对象就是此角色的实例。在java中由具体的类来实现。

下面以IE,火狐,谷歌浏览器为模型做简单的说明

(1)抽象产品角色

package abstractFactory;
/**
 * 抽象产品  ChromeDriver
 * @author Administrator
 *
 */
abstract class ChromeDriver {

    public abstract void openURL(String prmUrl);

    public abstract String findElement(String prmFindTyp);

    public abstract void closePage();
}
package abstractFactory;
/**
 * 抽象产品  FirefoxDriver
 * @author Administrator
 *
 */
abstract class FirefoxDriver{

    public abstract void openURL(String prmUrl);

    public abstract String findElement(String prmFindTyp);

    public abstract void closePage();
}
package abstractFactory;
/**
 * 抽象产品  FirefoxDriver
 * @author Administrator
 *
 */
abstract class InternetExplorerDriver {

    public abstract void openURL(String prmUrl);

    public abstract String findElement(String prmFindTyp);

    public abstract void closePage();

}

(2)具体产品角色

package abstractFactory;
/**
 * 具体产品  ChromeDriver
 * @author Administrator
 *
 */
public class ChromeDriverImpl extends ChromeDriver {
    @Override
    public void openURL(String prmUrl) {
        System.out.println("谷歌浏览器打开URL:" + prmUrl);

    }

    @Override
    public String findElement(String prmFindTyp) {
        System.out.println("谷歌浏览器定位元素方式:" + prmFindTyp);
        return "画面元素值为:ChromeDriver";
    }

    @Override
    public void closePage() {
        System.out.println("谷歌浏览器关闭页面");

    }

}
package abstractFactory;

/**
 * 具体产品  FirefoxDriver
 * @author Administrator
 *
 */
public class FirefoxDriverImpl extends FirefoxDriver {

    @Override
    public void openURL(String prmUrl) {
        System.out.println("火狐浏览器打开URL:" + prmUrl);

    }

    @Override
    public String findElement(String prmFindTyp) {
        System.out.println("火狐浏览器定位元素方式:" + prmFindTyp);
        return "画面元素值为:FirefoxDriver";
    }

    @Override
    public void closePage() {
        System.out.println("火狐浏览器关闭页面");

    }

}
package abstractFactory;
/**
 * 具体产品  InternetExplorerDriver
 * @author Administrator
 *
 */
public class InternetExplorerDriverImpl extends InternetExplorerDriver {

    @Override
    public void openURL(String prmUrl) {
        System.out.println("IE浏览器打开URL:" + prmUrl);

    }

    @Override
    public String findElement(String prmFindTyp) {
        System.out.println("IE浏览器定位元素方式:" + prmFindTyp);
        return "画面元素值为:IEDriver";
    }

    @Override
    public void closePage() {
        System.out.println("IE浏览器关闭页面");

    }

}

(3)抽象工厂角色

package abstractFactory;

/**
 * 简单的模拟 WebDriver的几个功能来说明工厂模式问题
 * Selenium的Jar中有此类,且方法远远多于此
 * @author Administrator
 *
 */
public abstract class WebDriver {

    public abstract ChromeDriver createChromeDriver();  

    public abstract FirefoxDriver createFirefoxDriver();  

    public abstract InternetExplorerDriver createIEDriver();  

}

(4)具体工厂角色

package abstractFactory;

/**
 * 具体工厂
 * @author Administrator
 *
 */
public class WebDriverFactory extends WebDriver {

    @Override
    public ChromeDriver createChromeDriver() {
        return  new ChromeDriverImpl();
    }

    @Override
    public FirefoxDriver createFirefoxDriver() {
        return  new FirefoxDriverImpl();
    }

    @Override
    public InternetExplorerDriver createIEDriver() {
        return  new InternetExplorerDriverImpl();
    }

}

(5)测试代码

package abstractFactory;

import org.junit.Test;

public class WebDriverFactoryTest {

    @Test
    public void testIEDriver() {
        WebDriver wd = new WebDriverFactory();
        //IE
        InternetExplorerDriver ied =  wd.createIEDriver();
        ied.openURL("www.baidu.com");
        ied.findElement("Xpath://div/a");
        ied.closePage();

        //火狐
        FirefoxDriver ffd =  wd.createFirefoxDriver();
        ffd.openURL("www.baidu.com");
        ffd.findElement("Xpath://div/a");
        ffd.closePage();

        //谷歌
        ChromeDriver ggd =  wd.createChromeDriver();
        ggd.openURL("www.baidu.com");
        ggd.findElement("Xpath://div/a");
        ggd.closePage();
    }

}

(6)测试结果

IE浏览器打开URL:www.baidu.com
IE浏览器定位元素方式:Xpath://div/a
IE浏览器关闭页面
火狐浏览器打开URL:www.baidu.com
火狐浏览器定位元素方式:Xpath://div/a
火狐浏览器关闭页面
谷歌浏览器打开URL:www.baidu.com
谷歌浏览器定位元素方式:Xpath://div/a
谷歌浏览器关闭页面
时间: 06-26

JAVA设计模式--抽象工厂模式的相关文章

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

抽象工厂模式(Abstract Factory Pattern)是属于创建型的设计模式,意在创造一个抽象的工厂,而后再由实例化出的具体的工厂来进行生产. 何时使用:系统的产品有多于一个的产品族,而系统只消费其中某一族的产品. 应用实例:工作了,为了参加一些聚会,肯定有两套或多套衣服吧,比如说有商务装(成套,一系列具体产品).时尚装(成套,一系列具体产品),甚至对于一个家庭来说,可能有商务女装.商务男装.时尚女装.时尚男装,这些也都是成套的,即一系列具体产品.假设一种情况(现实中是不存在的,要不然

Java设计模式——抽象工厂模式(Abstract factory)

抽象工厂模式可以向客户提供接口,使得客户端在不必指定产品具体类型的情况下创建多个产品族中的产品对象. 系统的设计 采用抽象工厂模式设计出的系统类图如下: 从上图可以看出,抽象工厂模式涉及到角色: 抽象工厂角色(AbstractFactory):担任这个角色的是工厂方法模式的核心,它与应用系统的商业逻辑无关.通常使用Java接口或者抽象Java类实现,而所有的具体工厂类都必须实现这个Java接口或者继承这个抽象Java类. 具体工厂类(ConcreteFactory)角色:这个角色直接在客户端的调

Java设计模式-抽象工厂模式(Abstract Factory )

工厂方法模式有一个问题就是,类的创建依赖工厂类,也就是说,如果想要拓展程序,必须对工厂类进行修改,这违背了闭包原则,所以,从设计角度考虑,有一定的问题,如何解决?就用到抽象工厂模式,创建多个工厂类,这样一旦需要增加新的功能,直接增加新的工厂类就可以了,不需要修改之前的代码. 为工厂类做一个统一的父类接口,可用于扩展 因为抽象工厂不太好理解,先看看图,然后就和代码,就比较容易理解. 例子: public interface Sender { public void Send(); } 两个实现类

设计模式-抽象工厂模式(C#)

设计模式--抽象工厂模式(JAVA) 在抽象工厂模式中,一个具体工厂可以生产一组相关的具体产品,这样的一组产品成为产品族,产品族中的每一个产品都属于某一个产品继承等等级结构.当系统所提供的工厂生产的具体产品并不是一个简单的对象,而是多个位于不同产品等级结构.属于不同类型的具体产品时就可以使用抽象工厂模式. 抽象工厂模式与工厂方法模式最大的区别在于,工厂方法模式针对的是一个产品等级结构,而抽象工厂模式需要面对多个产品等级结构,一个工厂等级结构可以负责多个不同产品等级结构中的产品对象的创建,当一个工

浅析JAVA设计模式之工厂模式(一)

1 工厂模式简介 工厂模式的定义:简单地说,用来实例化对象,代替new操作. 工厂模式专门负责将大量有共同接口的类实例化.工作模式可以动态决定将哪一个类实例化,不用先知道每次要实例化哪一个类. 工厂模式可以分一下三种形态: 简单工厂 (Simple Factory)模式:又称静态工厂模式(StaticFactory). 工厂方法 (Factroy Method)模式:又称多态性工厂模式(Polymorphic Factory). 抽象工厂 (Abstract Factroy)模式:又称工具箱模式

浅析JAVA设计模式之工厂模式(二)

1 工厂方法模式简介 工厂方法 (Factroy Method) 模式:又称多态性工厂模式(Polymorphic Factory),在这种模式中,核心工厂不再是一个具体的类,而是一个抽象工厂,提供具体工厂实现的接口,具体创建产品交由子工厂去做,抽象工厂不涉及任何产品被实例化的细节.而不同等级的产品,就对应一个不同等级的工厂,如下图. 图1 1.1工厂方法模式(多态性工厂模式): 工厂方法模式有三个角色: 1. 抽象产品接口 2. 具体产品类 3. 抽象工厂接口 4.具体工厂类. 1.2工厂方法

浅析JAVA设计模式之工厂模式(三)

在阅读本文之前,请先阅读(一)和(二)中的简单工厂模式和工厂方法模式. 1抽象工厂模式简介 抽象工厂 (Abstract Factroy) 模式:工具箱模式(kit).抽象工厂模式是所有形态的工厂模式中最为抽象和最具一般性的一种形态,如下图. 图1.1 上图左边有一个工厂类的等级结构,右边有两个不同的产品等级结构,分别是产品A的等级结构和产品B的等级结构,工厂1和工厂2分别负责不同一个产品等级,同一个产品族的产品的生产.又例如下图: 图1.2 上图表示的是Button和Text两个不同产品的等级

设计模式——抽象工厂模式学习

要想正确的理解设计模式,首先必须明确它是为了解决什么问题而提出来的. 抽象工厂设计模式概念: 针对抽象工厂这个设计模式,我查找了不少资料,感觉只有涉及产品级别和产品族的才是理解了抽象工厂设计模式的精髓,工厂方法模式针对的是一个产品等级结构:而抽象工厂模式针对的是多个产品等级结构.有些观点认为抽象工厂模式是为了解决客户端代码与工厂类的耦合问题,我认为这种观点的解决方案只是简单工厂模式的一个应用,而这种观点认为的抽象工厂模式是: 工厂模式+简单工厂模式=抽象工厂模式,这是不正确. 针对的问题: 针对

Java与设计模式-抽象工厂模式

首先说明,文章较长,保证你有耐心看完肯定能懂,没耐心直接点×即可. 抽象工厂模式,是创建型设计模式之一.抽象型工厂模式适合产品确定,产品线不确定的类型,怎么讲?通过一个具体例子来讲一下吧.例如某电脑厂商要生产电脑,也就是电脑这个产品确定,而电脑配置不确定,这种情况可以用抽象工厂模式来解决.类图如图所示: 代码实现完全结合UML类图,结合图就可以完成系统创建. 本实例里是抽象类ComputerFactory(对应UML类图中的AbstractFactory): package com.factor