大B:“你喜欢奥迪audi车吗?”
小A:“嘿嘿!喜欢。”
大B:“我就举个奥迪audi车的例子,让你更好地理解抽象工厂模式。”
小A:“好啊!”
大B:“介绍了工厂方法的使用,从那个程序中可以看到,奥迪audi车是从audicarfactoryimple工厂中创建出来的,而大众3W车是从threeWcarfactoryimple工厂中创建出来的,那么如果这2家汽车生产大厂由总部在北京市,现在发展到上海,深圳等城市创建生气汽车的分厂,该怎么办?是不是得将原来的奥迪汽车工厂类。”
publicclassaudicarfactoryimpleimplementsIcarfactory{
publicIcarinterfacecreatecar(){
caraudiimplecaraudiimpleref=newcaraudiimple();
caraudiimpleref.setName(“奥迪A6”);
caraudiimpleref.setSpeed(300);
returncaraudiimpleref;
}
}
改成类似如下的模样:
publicclassaudicarfactoryimpleimplementsIcarfactory{
publicIcarinterfacecreatecar(Stringareacar){
if(areacar.equals(“北京”)){创建一个北京的奥迪汽车}
if(areacar.equals(“上海”)){创建一个上海的奥迪汽车}
if(areacar.equals(“深圳”)){创建一个深圳的奥迪汽车}
returncaraudiimpleref;
}
}
小A:“发现一个问题,不同地域的汽车却在一个工厂中出现。”
大B:“这是不合乎常理的,因为北京奥迪在北京分厂创建,上海奥迪在上海分厂创建,这样才对。所以如果遇到分‘大系’来创建对象的时候,抽象工厂方法是肯定要使用的时候了。”
小A:“什么是‘大系’?”
大B:“这里的大系指的就是从地域上来分。这个例子就应该以‘用抽象工厂来定义具体工厂的抽象,而由具体工厂来创建对象’。 比如在玩‘极品飞车’这款游戏,每个地图处都有造车的工厂,每个造车的工厂都因为有造车的档次不同而划分为高级车厂,低级车厂,那么这样的场景正是应用抽象工厂的好时机,再来理解一下这句话‘用抽象工厂来定义具体工厂的抽象,而由具体工厂来创建对象’,用抽象造车工厂来定义具体造车工厂的抽象,而由具体的造车工厂来创建汽车,这就是抽象工厂与工厂方法的不同,工厂方法中对象的创建是由工厂方法来确定的,创建的对象都是不分类并且实现一个接口的,而抽象工厂就是在工厂方法的基础上对创建车的对象的行为进行分类,比如北京车厂,上海车厂等。”
【抽象工厂模式解释。
类型:创建模式
提供一个创建一系列相关或相互依赖对象的接口,而无需指定他们具体的类。
【抽象工厂模式-J**A代码实现。
新建抽象工厂接口:
packagecarfactoryinterface;
importcarinterface.Icarinterface;
publicinterfaceIcarfactory{
publicIcarinterfacecreatethreeWcar();
publicIcarinterfacecreateaudicar();
}
新建抽象工厂接口的高级车adv工厂实现类:
packagecarfactoryimple;
importcarfactoryinterface.Icarfactory;
importcarimple.car3wimpleadv;
importcarimple.caraudiimpleadv;
importcarinterface.Icarinterface;
publicclasscarfactoryadvimplementsIcarfactory{
publicIcarinterfacecreateaudicar(){
caraudiimpleadvcaraudiimpleadv=newcaraudiimpleadv();
caraudiimpleadv.setName(“奥迪A6”);
caraudiimpleadv.setSpeed(300);
returncaraudiimpleadv;
}
publicIcarinterfacecreatethreeWcar(){
car3wimpleadvcar3wimpleadvref=newcar3wimpleadv();
car3wimpleadvref.setName(“大众A6”);
car3wimpleadvref.setSpeed(300);
returncar3wimpleadvref;
}
}
新建抽象工厂接口的普通车low工厂实现类:
packagecarfactoryimple;
importcarfactoryinterface.Icarfactory;
importcarimple.car3wimplelow;
importcarimple.caraudiimplelow;
importcarinterface.Icarinterface;
publicclasscarfactorylowimplementsIcarfactory{
publicIcarinterfacecreateaudicar(){
caraudiimplelowcaraudiimplelowref=newcaraudiimplelow();
caraudiimplelowref.setName(“奥迪A6”);
caraudiimplelowref.setSpeed(300);
returncaraudiimplelowref;
}
publicIcarinterfacecreatethreeWcar(){
car3wimplelowcar3wimplelowref=newcar3wimplelow();
car3wimplelowref.setName(“大众A6”);
car3wimplelowref.setSpeed(300);
returncar3wimplelowref;
}
}
上面已经有抽象工厂和具体工厂的实现类了。
新建汽车接口:
packagecarinterface;
publicinterfaceIcarinterface{
publicvoidstart();
publicvoidstop();
}
新建汽车父类:
packagecarimple;
importcarinterface.Icarinterface;
publicclassbasecarimpleimplementsIcarinterface{
privateintspeed;
privateStringname;
publicintgetSpeed(){
returnspeed;
}
publicvoidsetSpeed(intspeed){
this.speed=speed;
}
publicStringgetName(){
returnname;
}
publicvoidsetName(Stringname){
this.name=name;
}
publicvoidstart(){
//TODOAuto-generatedmethodstub
}
publicvoidstop(){
//TODOAuto-generatedmethodstub
}
}
新建大众高级车:
packagecarimple;
importcarinterface.Icarinterface;
publicclasscar3wimpleadvextendsbasecarimple{
publicvoidstart(){
System.out.println(富华版:+this.getName()+车以专利技术起动了最高速度为:
+this.getSpeed());
}
publicvoidstop(){
System.out.println(富华版:“+this.getName()+”车以专利技术停车了);
}
}
新建大众普通车:
packagecarimple;
importcarinterface.Icarinterface;
publicclasscar3wimplelowextendsbasecarimple{
publicvoidstart(){
System.out.println(普通版:+this.getName()+车以专利技术起动了最高速度为:
+this.getSpeed());
}
publicvoidstop(){
System.out.println(普通版:“+this.getName()+”车以专利技术停车了);
}
}
新建大众普通车:
packagecarimple;
importcarinterface.Icarinterface;
publicclasscaraudiimpleadvextendsbasecarimple{
publicvoidstart(){
System.out.println(富华版:+this.getName()+车以专利技术起动了最高速度为:
+this.getSpeed());
}
publicvoidstop(){
System.out.println(富华版:“+this.getName()+”车以专利技术停车了);
}
}
新建奥迪普通车:
packagecarimple;
importcarinterface.Icarinterface;
publicclasscaraudiimplelowextendsbasecarimple{
publicvoidstart(){
System.out.println(普通版:+this.getName()+车以专利技术起动了最高速度为:
+this.getSpeed());
}
publicvoidstop(){
System.out.println(普通版:“+this.getName()+”车以专利技术停车了);
}
}
新建客户端运行类:
packagerunmain;
importcarfactoryimple.carfactoryadv;
importcarfactoryinterface.Icarfactory;
importcarinterface.Icarinterface;
publicclassrunmain{
publicstaticvoidmain(String[]args){
IcarfactoryIcarfactoryref=newcarfactoryadv();
IcarinterfaceIcarinterfaceref=Icarfactoryref
createthreeWcar();
Icarinterfaceref.start();
Icarinterfaceref.stop();
}
}
程序运行结果如下:
富华版:大众A6车以专利技术起动了最高速度为:300
富华版:大众A6车以专利技术停车了
一开始只在后花园中种蔬菜类的时候可以用简单工厂模式,由工厂负责生成具体的蔬菜类,
但是如果后花园要引进水果类的时候简单模式就行不通了,因此需要使用工厂方法模式,将产品类族分开。
但是如果后花园的规模继续扩大到地域范围的分割时,比如说一个在北京,一个在上海的时候,工厂方法模式就不够了,因为对两个后花园来说,每个后花园的植物是要被种在一起的,并且两个后花园用工厂方法模式是无法体现其区别的。
从程序中可以看到,工厂是抽象的,工厂的实现是不一样的,不同的工厂创建出不同汽车。而工厂方法仅仅是用一个工厂去创建很多汽车。