(转)java反射机制及简单工厂模式

第一步,定义一个接口类

package factory.face;  

/**
* 接口,为了保证返回的对象可以统一用 Product接受
* @author Administrator
*/ public interface Product { void show(); }

第二步,写两个继承了以上接口的类

package factory.extend;

import factory.face.Product;

public class ProductA implements Product{
@Override
public void show() {
System.out.println("This is Product A!");
}
}
package factory.extend;

import factory.face.Product;

public class ProductB  implements Product{

	@Override
public void show() {
System.out.println("This is Product B!");
}
}

第三步,工厂类中应用反射机制

package factory.main;  

import factory.face.Product;  

/**
* 工厂类,在生产具体产品的时候,客户端只需要调用Factory 中的静态方法就可
* @author Administrator
*
*/ public class Factory { public static Product getProduct(String className) throws InstantiationException, IllegalAccessException, ClassNotFoundException {
return (Product)Class.forName(className).newInstance();
} public static void main(String[] srgs) throws InstantiationException, IllegalAccessException, ClassNotFoundException {
// System.out.println("WWWW");
// Class<?> classA = Class.forName("factory.extend.ProductA");
// Product aProduct = (Product)classA.newInstance();
// aProduct.show(); Product a= Factory.getProduct("factory.extend.ProductA");
a.show();
Product b=Factory.getProduct("factory.extend.ProductB");
b.show();
}
}

运行结果:

This is Product A!
This is Product B!
以下方式,是未使用反射机制的简单工厂类,根据判断逻辑来创建具体产品
public class Factory{

	public static Product getProduct(int product_index){

		if(product_index==0)
return new ProductA(); if(1==product_index)
return new ProductB(); return null;
}
}

简单工厂模式的优缺点:

优点:模式的核心是工厂类。这个类含有必要的判断逻辑,可以决定创建哪一个产品类的实例。而客户端免去了直接创建产品对象的责任,而仅仅负责“消费”产品。简单工厂模式通过这种做法实现了对责任的分割。

缺点:当产品类有复杂的多层次等级结构时,工厂类只有他自己。由于工厂类集中了所有产品创建逻辑的,如果不能正常工作的话会对系统造成很大的影响。如果使用常规的判断方法,在工厂里根据传入的参数的不同而实例化产品对象的话,代码是不可用的,因为如果增加新产品必须修改工厂角色的源码,不利于以后的维护。

上一篇:纯CSS绘制三角形(各种角度)类似于使用字符画法,根据位移不同,也可以使用两个元素画出三角边框


下一篇:h5弹框去掉ip地址