Java 工厂模式学习
工厂模式分三种:简单工厂、工厂方法、抽象工厂。其中抽象工厂是用于多个产品族的情况。所谓产品族就是不同产品组成的有机整体,各不同产品之间相互依赖。打个比方,一台电脑有CPU、主板、内存和硬盘等,这些不同产品组成了一个产品族。就好比Dell和HP要把这些产品进行不同的组装,这时就需要用到抽象工厂。以下是代码演示:
简单工厂,可以用反射实现:
首先定义产品的抽象接口
package com.demo.SimpleFactory; public interface CPU {
public void run();
}
定义具体产品
package com.demo.SimpleFactory; public class Intel implements CPU { @Override
public void run() {
// TODO Auto-generated method stub
System.out.println("This is Intel!");
} }
package com.demo.SimpleFactory; public class Amd implements CPU { @Override
public void run() {
// TODO Auto-generated method stub
System.out.println("This is Amd!");
} }
定义工厂类
package com.demo.SimpleFactory; public class Factory {
public static CPU create(String str) {
CPU c = null;
try {
c = (CPU) Class.forName("com.demo.SimpleFactory." + str)
.newInstance(); } catch (Exception e) {
e.printStackTrace();
}
return c;
}
}
测试如下
package com.demo.SimpleFactory; public class Test {
public static void main(String[] args){
CPU c=Factory.create("Amd");
c.run();
}
}
打印结果:
This is Amd!
工厂方法
首先定义产品的抽象接口
package com.demo.SimpleFactory; public interface CPU {
public void run();
}
定义具体产品
package com.demo.SimpleFactory; public class Intel implements CPU { @Override
public void run() {
// TODO Auto-generated method stub
System.out.println("This is Intel!");
} }
package com.demo.SimpleFactory; public class Amd implements CPU { @Override
public void run() {
// TODO Auto-generated method stub
System.out.println("This is Amd!");
} }
定义抽象工厂,具体现实由其子类负责
package com.demo.FactoryMethod; public interface FactoryMethod {
public CPU create();
}
具体子类工厂
package com.demo.FactoryMethod; public class AmdFactory implements FactoryMethod { @Override
public CPU create() {
// TODO Auto-generated method stub
return new Amd();
} }
package com.demo.FactoryMethod; public class IntelFactory implements FactoryMethod {
public CPU create() {
return new Intel();
}
}
测试
package com.demo.FactoryMethod; public class Test { public static void main(String[] args) {
FactoryMethod af=new IntelFactory();
CPU c=af.create();
c.run();
}
}
打印结果:
This is Intel!
抽象工厂
首先定义产品的抽象接口
package com.demo.SimpleFactory; public interface CPU {
public void run();
}
定义具体产品
package com.demo.SimpleFactory; public class Intel implements CPU { @Override
public void run() {
// TODO Auto-generated method stub
System.out.println("This is Intel!");
} }
package com.demo.SimpleFactory; public class Amd implements CPU { @Override
public void run() {
// TODO Auto-generated method stub
System.out.println("This is Amd!");
} }
package com.demo.AbstractFactory; public interface Memory {
public void read(String str);
}
package com.demo.AbstractFactory; public class KingstonMemory implements Memory { public KingstonMemory() {
// TODO Auto-generated constructor stub
} @Override
public void read(String str) {
// TODO Auto-generated method stub
System.out.println("Kingston Read data is:"+str);
} }
package com.demo.AbstractFactory; public class AdataMemory implements Memory { public AdataMemory() {
// TODO Auto-generated constructor stub
} @Override
public void read(String str) {
// TODO Auto-generated method stub
System.out.println("Adata read data is:"+str);
} }
定义抽象工厂
package com.demo.AbstractFactory; public interface AbstractFactory { public CPU createCPU(); public Memory createMemory();
}
不同子类产生不同产品族
package com.demo.AbstractFactory; public class DellFactory implements AbstractFactory { @Override
public CPU createCPU() {
// TODO Auto-generated method stub
return new Intel();
} @Override
public Memory createMemory() {
// TODO Auto-generated method stub
return new KingstonMemory();
} }
package com.demo.AbstractFactory; public class HPFactory implements AbstractFactory { @Override
public CPU createCPU() {
// TODO Auto-generated method stub
return new Amd();
} @Override
public Memory createMemory() {
// TODO Auto-generated method stub
return new AdataMemory();
} }
测试
package com.demo.AbstractFactory; public class Test {
public static void main(String[] args){
AbstractFactory hp=new HPFactory();
CPU cpu=hp.createCPU();
Memory memory=hp.createMemory();
cpu.run();
memory.read("Pass");
}
}
打印结果:
This is Amd!
Adata read data is:Pass
Java 工厂模式学习的更多相关文章
- java工厂模式
(1)概念大白话:java工厂模式就是客户端(main函数)要创建对象觉得麻烦就让另外一个叫工厂的类帮它创建,然后自己每次要创建对象就叫工厂帮它弄,举个例子,在没有工厂这个"手下" ...
- Java工厂模式解耦 —— 理解Spring IOC
Java工厂模式解耦 -- 理解Spring IOC 最近看到一个很好的思想来理解Spring IOC,故记录下来. 资源获取方式 主动式:(要什么资源都自己创建) 被动式:(资源的获取不是我们创建, ...
- Java学习笔记——Java工厂模式之简单工厂
package com.app; import java.util.Date; /* * 工厂模式:简单工厂.工厂方法.抽象工厂 * * */ public class Test0718_Factor ...
- java设计模式之抽象工厂模式学习
工厂模式有个问题就是,类的创建依赖工厂.要想增加一个工厂类,就要修改原来的代码,这违背了闭包原则.所以,从设计角度考虑,有一定的问题,如何解决?就用到抽象工厂模式,创建多个工厂类,这样一旦需要增加新的 ...
- java设计模式之工厂模式学习
上周安排的写两篇设计模式的文章,结果一篇也没写,今天都给写了.回顾+反思.In this world he who stops ,won't get anything he wants! 工厂方法模式 ...
- 自己理解的java工厂模式,希望对大家有所帮助
[http://www.360doc.com/content/11/0824/17/3034429_142983837.shtml] 这两天突然想学学java源代码,不过看到一篇文章说看java源代码 ...
- JAVA - 工厂模式
1. 简单工厂违背OCP(Open Close Principle)原则 , 即对增加开放,对修改关闭.如果要符合OCP原则,要针对接口编程. //简单工厂模式,违反了OCP原则 public cla ...
- Java 工厂模式(一)— 抽象工厂(Abstract Factory)模式
一.抽象工厂模式介绍: 1.什么是抽象工厂模式: 抽象工厂模式是所有形态的工厂模式中最为抽象和最具有一般性的一种形态,抽象工厂模式向客户端提供一个接口,使得客户端在不知道具体产品的情类型的情况下,创建 ...
- Java 工厂模式(一)— 简单工厂模式
一.什么是工厂模式: Java中的工厂模式主要是用来将有大量共同接口的类实例化.工厂模式可以动态的决定将哪一个类实例化,不必事先知道要实例化哪个类,将类的实例化的主动权交给工厂而不是类本身.我们常见的 ...
随机推荐
- .NET系统架构改造的经验和教训
转自: http://robbinfan.com/blog/43/rid-off-dotnet-experience 在互联网行业,基于Unix/Linux的网站系统架构毫无疑问是当今主流的架构解决方 ...
- RadioButtonList选择事件onclick
<asp:RadioButtonList ID="rbtnFInvoiceType" runat="server" onclick="check ...
- SQL Server 创建作业系列问题
一.从IClassFactory为CLSID为{AA40D1D6-CAEF-4A56-B9BB-D0D3DC976BA2}的COM组件创建实例失败. 尊重原著作:本文转载自http://www.hao ...
- EXT.NET常用属性
Ext_数字输入框_Ext.form.NumberField: <mce:script type="text/javascript"><!-- /* Ext. ...
- The executable was signed with invalid entitlements新设备run出现这个问题
出现这个问题一般是新手不熟悉开发者发布流程造成地 一定要安开发者流程一步一步走 这样就不会出错了 注意这几个地方地设置 1.
- Repeater控件实现数据绑定,并实现分页效果
前台显示代码 <pre name="code" class="csharp"><asp:Repeater ID="Repeater1 ...
- (转载)iscroll.js的使用
入门 Scroll是一个类,每个需要使用滚动功能的区域均要进行初始化.每个页面上的iScroll实例数目在设备的CPU和内存能承受的范围内是没有限制的. 尽可能保持DOM结构的简洁.iScroll使用 ...
- Android 自定义下拉刷新ListView
package com.dwtedx.qq.view; import android.content.Context; import android.util.AttributeSet; import ...
- 一维树状数组(HD1166)
#define _CRT_SECURE_NO_WARNINGS #include<iostream> #include<string.h> using namespace st ...
- CPrimer Plus第12章 存储类、链接和内存管理随笔
被static修饰的属于内部链接,不可被外部程序文件所使用一般而言,全局变量(文件作用域变量)具有静态存储期,局部变量(代码块作用域变量)具有自动存储期寄存器变量不能使用地址运算符因为被static修 ...