`
wangyanlong0107
  • 浏览: 504835 次
  • 性别: Icon_minigender_1
  • 来自: 沈阳
社区版块
存档分类
最新评论

【转】静态工厂模式static factory method(简单工厂模式 simple facotry)

 
阅读更多

一、静态工厂方法模式(简单工厂模式)

为水果类声明了一个接口,表现在代码上:

 1 public   interface  Fruit {
 2      // 生长
 3       void  grow();
 4       // 收获
 5       void  harvest();
 6       // 种植
 7       void  plant();
 8 }

 9
10

 

package  fac;

public   class  Apple  implements  Fruit { // 通过implements实现接口Fruit
     private   int  treeAge;
    
    
public   void  grow() {
        log(
" Apple is growing " );
    }

    
    
public   void  harvest() {
        log(
" Apple has been harvested " );
    }

    
    
public   void  plant() {
        log(
" Apple ha been planted " );
    }

    
    
public   static   void  log(String msg) {
        System.out.println(msg);
    }

    
    
public   int  getTreeAge() {
        
return  treeAge;
    }

    
    
public   void  setTreeAge( int  treeAge) {
        
this .treeAge = treeAge;
    }

}

 

package fac;

public class Grape implements Fruit{
    
private boolean seedless;
    
public void grow(){
        log(
"Grape is growing.");
    }

    
    
public void harvest(){
        log(
"Grape has been harvested");
    }

    
    
public void plant(){
        log(
"Grape ha been planted");
    }

    
    
public static void log(String msg){
        System.out.println(msg);
    }


    
public boolean isSeedless() {
        
return seedless;
    }


    
public void setSeedless(boolean seedless) {
        
this.seedless = seedless;
    }

    

}

 

package fac;

public class Strawberry implements Fruit{
    
public void grow(){
        log(
"Strawberry is growing");
    }

    
    
public void harvest(){
        log(
"Strawberry has been harvested");
    }

    
    
public void plant(){
        log(
"Strawberry has been planted");
    }

    
    
public static void log(String msg){
        System.out.println(msg);
    }

}

 

package fac;

public class FruitGardener{
    
public static Fruit factory(String which)throws Exception{
        
if(which.equalsIgnoreCase("apple")){
            
return new Apple();
        }
else if(which.equalsIgnoreCase("strawberry")){
            
return new Strawberry();
        }
else if (which.equalsIgnoreCase("grape")){
            
return new Grape();
        }
else{
            
throw new Exception("Bad fruit request");
        }

    }

}

 

package fac;

public class People {

    
public static void main(String[] args) throws Exception {
        FruitGardener fg
=new FruitGardener();
        Fruit ap
=fg.factory("Apple");
        ap.grow();
        Fruit gp
=fg.factory("Grape");
        gp.plant();
        
        Fruit dd
=fg.factory("ddd");//抛出Bad fruit request异常
    }
    

}


(注:以上代码在JDK5.0,Myeclise3.2下编译通过)


理解了以下两个例子,再来看第三个例子:
注意对比以下三个实例的不同
实例1:

package org.jzkangta.factorydemo01;
//定义接口
interface Car{
    
public void run();
    
public void stop();
}

//具体实现类
class Benz implements Car{
    
public void run(){
        System.out.println(
"Benz开始启动了。。。。。");
    }

    
public void stop(){
        System.out.println(
"Benz停车了。。。。。");
    }

}

//具体实现类
class Ford implements Car{
    
public void run(){
        System.out.println(
"Ford开始启动了。。。");
    }

    
public void stop(){
        System.out.println(
"Ford停车了。。。。");
    }

}

//工厂
class Factory{
    
public static Car getCarInstance(){
        
return new Ford();
    }

}

public class FactoryDemo01 {

    
public static void main(String[] args) {
        Car c
=Factory.getCarInstance();
        c.run();
        c.stop();

    }


}


实例二:

package fac;


//定义接口
interface Car{
    
public void run();
    
public void stop();
}

//具体实现类
class Benz implements Car{
    
public void run(){
        System.out.println(
"Benz开始启动了。。。。。");
    }

    
public void stop(){
        System.out.println(
"Benz停车了。。。。。");
    }

}


class Ford implements Car{
    
public void run(){
        System.out.println(
"Ford开始启动了。。。");
    }

    
public void stop(){
        System.out.println(
"Ford停车了。。。。");
    }

}

//工厂
class Factory{
    
public static Car getCarInstance(String type){
        Car c
=null;
        
if("Benz".equals(type)){
            c
=new Benz();
        }

        
if("Ford".equals(type)){
            c
=new Ford();
        }

        
return c;
    }

}



public class FactoryDemo02 {

    
public static void main(String[] args) {
        Car c
=Factory.getCarInstance("Benz");
        
if(c!=null){
            c.run();
            c.stop();
        }
else{
            System.out.println(
"造不了这种汽车。。。");
        }

        

    }


}



实例三:

interface Car{
    
public void run();
    
public void stop();
}


class Benz implements Car{
    
public void run(){
        System.out.println(
"Benz开始启动了。。。。。");
    }

    
public void stop(){
        System.out.println(
"Benz停车了。。。。。");
    }

}


class Ford implements Car{
    
public void run(){
        System.out.println(
"Ford开始启动了。。。");
    }

    
public void stop(){
        System.out.println(
"Ford停车了。。。。");
    }

}


class Toyota implements Car{
    
public void run(){
        System.out.println(
"Toyota开始启动了。。。");
    }

    
public void stop(){
        System.out.println(
"Toyota停车了。。。。");
    }

}


class Factory{
    
public static Car getCarInstance(String type){
        Car c
=null;
        
try {
            c
=(Car)Class.forName("org.jzkangta.factorydemo03."+type).newInstance();//利用反射得到汽车类型 
        }
 catch (InstantiationException e) {
            
// TODO Auto-generated catch block
            e.printStackTrace();
        }
 catch (IllegalAccessException e) {
            
// TODO Auto-generated catch block
            e.printStackTrace();
        }
 catch (ClassNotFoundException e) {
            
// TODO Auto-generated catch block
            e.printStackTrace();
        }

    
        
return c;
    }

}

public class FactoryDemo03 {

    
public static void main(String[] args) {
        Car c
=Factory.getCarInstance("Toyota");
        
if(c!=null){
            c.run();
            c.stop();
        }
else{
            System.out.println(
"造不了这种汽车。。。");
        }

        

    }


}


对比三个实例:
实 例一,虽然实现了简单工厂,但每次只能得到一种汽车,如果我们想换一种,就得修改工厂,太不方便,而实例二则改变了这种情况,便得我们可以按照我们的需要 更换汽车,但我们所更换的汽车必须是实现类中有的,如果我们想要增加一种汽车的时候,我们还是得更改工厂,通过改进,实例三利用反射机制,得到汽车类型, 这样当我们需要增加一种新的汽车时,就无需要再修改工厂,而只需要增加要实现的类即可。也就是说要增加什么样的汽车直接增加这个汽车的类即可,而无需改变 工厂。从而达到了工厂分离的效果。

分享到:
评论

相关推荐

    罗克韦尔自动化 Facotry Talk技术数据(中文).pdf

    罗克韦尔自动化 Facotry Talk技术数据(中文)pdf,罗克韦尔自动化 Facotry Talk技术数据(中文)

    Hibernte使用及配置说明

    ### Hibernate使用及配置详解 #### 一、Hibernate简介与优势 **Hibernate** 是一个开源的对象关系映射(Object-Relational Mapping,简称 ORM...这种模式不仅能够提高开发效率,还能增强应用程序的可维护性和扩展性。

    阿里java手册

    9. 推荐在类名中体现出所使用的具体设计模式,如工厂模式(Facotry)、代理模式(Proxy)、观察者模式(Observer)等。 10. 接口类中的方法和属性不建议使用修饰符,应保持简洁并添加javadoc注释,变量尽量不要定义在接口...

    Android App中使用Pull解析XML格式数据的使用示例

    Pull解析XML文件的方式与SAX解析XML文件的方式大致相同,他们都是基于事件驱动的。...下面的几个方法是经常需要的:XMLPullParserFacotry.newInstance( ) facotry.newPullParser( ) parser.setInput( ) par

    数据集 + 标题 法国Embouchure地区沉积物岩性数据集

    法国Embouchure地区沉积物岩性数据集 内容 该数据集由O. Puertas在2014年发布,详细记录了法国Embouchure地区的EMBOU岩芯沉积物的岩性特征。数据集中包含了39个数据点,提供了关于该地区沉积环境的重要信息。欲了解更多信息,请访问"PANGAEA数据库中的原始数据" ()。

    BH1750光照强度传感器.pdf

    BH1750光照强度传感器

    基于多目标粒子群算法的分布式电源选址定容与优化配置研究-基于MATLAB的程序实践与优化探讨,基于多目标粒子群算法的分布式电源选址定容与优化配置MATLAB程序:含规划模型、算法求解及参考文章赠阅

    基于多目标粒子群算法的分布式电源选址定容与优化配置研究——基于MATLAB的程序实践与优化探讨,基于多目标粒子群算法的分布式电源选址定容与优化配置MATLAB程序:含规划模型、算法求解及参考文章赠阅,分布式电源选址定容与优化配置MATLAB程序基于多目标粒子群算法 (1)该程序为基于多目标粒子群算法的分布式电源优化配置与选址定容程序,期刊lunwen源程序,配有该lunwen。 (2)本程序可有效配置分布式电源容量与安装位置。程序与lunwen包含的内容有综合成本、网损、电压稳定裕度为目标函数建立分布式电源的规划模型、多目标粒子群算法、IEEE-69节点的算例求解。 (3)赠送若干极为相似的参考lunwen,均为本人研究该课题期间认为非常系统、全面、易懂、基础的文章。 ,1. 多目标粒子群算法; 2. 分布式电源优化配置; 3. 分布式电源选址定容; 4. MATLAB程序; 5. 综合成本; 6. 网损; 7. 电压稳定裕度; 8. IEEE-69节点; 9. 参考lunwen(或相关文章),基于多目标粒子群算法的分布式电源选址定容与优化配置MATLAB程序:成本、网损与电压稳定的综

    数据集 + 标题 sediment core GeoB17620-1的文档记录

    sediment core GeoB17620-1的文档记录 内容 Lucchi, RG; Sabbatini, A; Nicolaisen, LS 等(2014年)提供的sediment core GeoB17620-1的文档记录。详细信息请访问"此链接" ()以获取完整的数据集文档和相关信息。请注意,文档的具体大小未知。

    基于多种语言的心理学网站前端开发设计源码

    该项目是一款多语言心理咨询网站前端开发设计源码,包含7166个文件,涵盖2646个PHP文件、1419个JavaScript文件、650个GIF文件、417个HTML文件、318个PNG文件、263个LESS文件、236个Vue文件、219个JSON文件、183个Markdown文件、142个文本文件。主要采用JavaScript进行开发,同时融入PHP、TypeScript、Shell等多种语言技术。这套源码旨在提供全面的心理咨询服务网站界面设计。

    显微镜下染色体图像分割系统:新手入门宝典.zip

    显微镜下染色体图像分割系统:新手入门宝典

    物品识别与分类系统源码和数据集:改进yolo11-HWD.zip

    物品识别与分类系统源码和数据集:改进yolo11-HWD

    【C#】Grpc扩展是一个基于GRPC的简单微服务框架.zip

    【C#】Grpc扩展是一个基于GRPC的简单微服务框架

    【GO】基于go实现的生日提醒定时任务.zip

    【GO】基于go实现的生日提醒定时任务

    数据集 + 标题 深海沉积物岩芯GeoB17624-3的文档记录

    深海沉积物岩芯GeoB17624-3的文档记录 内容 Lucchi, RG; Sabbatini, A; Nicolaisen, LS 等(2014)提供的文档包括了对深海沉积物岩芯GeoB17624-3的研究资料。该研究的具体数据集大小未知,但已通过PANGAEA数据库发布,可供进一步学术研究和参考。可通过以下链接访问完整数据集:"" ()。

    外科工具实例分割系统源码和数据集:改进yolo11-convnextv2.zip

    外科工具实例分割系统源码和数据集:改进yolo11-convnextv2

    图形化探索布莱克-斯科尔斯-默顿期权定价模型Matlab代码.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    AI人脸识别学习,使用opencv2.zip

    AI人脸识别学习,使用opencv2

    2024年第29届'21世纪杯'全国大学生英语演讲比赛西邮校园赛报名通知与规则解读

    内容概要:本通知介绍了西安邮电大学将举办的2024年第29届“21世纪杯”全国大学生英语演讲比赛的具体情况。活动目的是提升学生讲好中国故事的能力,促进文化交流与构建人类命运共同体。此次活动的主题是传统文化的复兴。主要内容涵盖比赛的背景介绍、参赛对象限定以及具体报名方式及时间节点。此外还详细讲解了演讲主题及视频上传的要求。评分标准从内容质量、语言表述、整体表现等方面进行了明确规定。获奖学生不仅将得到相应的表彰奖励,还有可能代表西安邮电大学参与到更高层级的比赛当中去。 适合人群:全体在校本科生,尤其是对外语学习感兴趣的师生;以及对于传统文化复兴有兴趣的年轻人。 使用场景及目标:此活动鼓励学生积极参与英语演讲竞技,提高自己的英语表达能力和综合素质,同时也有助于推广中国传统优秀文化传播。 其他说明:研究生(青年组)需要直接通过官网报名并且不受本次比赛限制;此外,该次比赛的成绩还将影响其他英语演讲系列竞赛的表现评估体系。未尽事宜将在日后进一步发布。

    基于Java开发的自然管理后台设计源码

    该项目是一款采用Java编写的自然管理后台设计源码,包含共计126个文件,涵盖95个Java源代码文件、18个XML配置文件、5个YAML文件、4个Git忽略文件、4个属性文件以及其他类型文件。此系统专注于后台管理功能,适用于各种管理场景。

    太阳能光伏面板分割系统:基础知识铺垫.zip

    太阳能光伏面板分割系统:基础知识铺垫

Global site tag (gtag.js) - Google Analytics