一、工厂方法模式涉及角色
1、抽象产品:产品对象共用接口或者父类;
2、具体产品:实现抽象产品的具体类;
3、抽象工厂:工厂方法模式的核心,定义创建产品的接口;
4、具体工厂:实现产品创建的接口。
二、使用场景和说明
(1)良好的封装性,代码结构清晰。客户端不需要创建具体产品对象的艰辛过程,降低模块间的耦合。
(2)其次,工厂方法模式的扩展性非常优秀。在
增加产品类的情况下,只要适当修改具体的工厂类或
扩展一个工厂类,就可以完成“
拥抱变化”。
(3)
屏蔽产品类。产品类的实现,调用者不需要关心,它只需要关心产品接口,只要接口保持不变,系统中的上层模块就不要发生变化。
(4)工厂方法模式是典型的
解耦框架
。高层模块只需要知道产品的抽象类,其他的实现类不用关心,符合迪米特法则,也符合依赖倒置原则。
三、代码实例
public abstract class People {
//公共的方法
public void eat() {
System.
out
.println(
"People.eat()是公共方法,大家都需要吃饭来维持生命。"
);
}
//抽象方法
public abstract void speakLanguage();
}
public class American
extends People {
public void speakLanguage() {
System.
out.println(
"American.speakLanguage(),我是美国人,我的母语是英语哟。");
}
}
public class Chinese extends People {
public void speakLanguage() {
System.
out.println(
"Chinese.speakLanguage(),我是中国人,母语是伟大的汉语。");
}
}
public abstract class Create {
public abstract <
T
extends People>
T createPeople(Class<
T> people);
}
public class ConcreteCreater
extends Create {
public <
T
extends People>
T createPeople(Class<
T> people) {
People people1 =
null;
try {
people1 = (People) Class.
forName(people.getName()).newInstance();
}
catch (Exception e) {
e.getStackTrace();
}
return (
T) people1;
}
}
public class TestFac {
public static void main(String[] args) {
//创建类
Create c =
new ConcreteCreater();
//实例化对象
People chin = c.createPeople(Chinese.
class);
chin.eat();
chin.speakLanguage();
People Ameri = c.createPeople(American.
class);
Ameri.speakLanguage();
}
}