现在的位置: 首页 > 综合 > 正文

简单工厂模式

2018年05月19日 ⁄ 综合 ⁄ 共 856字 ⁄ 字号 评论关闭

看了工厂模式的概念,感觉比较晦涩,用个人的话语来说,工厂模式就是用来提供对象的


比如在service层中需要调用dao层的类,就需要在service类中new dao()来创建dao对象,然后调用dao中的方法,这样的硬编码不利于以后代码的维护,为什么?因为如果在这个service类中调用了几百个甚至更多的dao类,如果dao类的实现方法改变了,如本来是jdbc,需要改成hibernate,那么就需要修改service中的这几百个dao类,这是一个多么庞大的工作。

所以可以用简单工厂模式来解决这个问题,用工厂类来提供对象,service不关心对象是怎么来的。具体代码实现如下:

定义一个抽象类,如操作数据的dao层

abstract class Dao{
    abstract void add(); //增 (删改省略)
}

有两个子类继承这个抽象类,实现里面的方法。jdbc和hibernate操作数据库的方式

class JdbcDao extends Dao{
    public void add(){
        System.out.println("jdbc实现dao的增加方法");
    }
}

class HibernateDao extends Dao{
    public void add(){
        System.out.println("Hibernate实现dao的增加方法");
    }
}

提供一个工厂类,根据传递过来的参数,决定是调用jdbc还是hibernate

class DBFactory {
    public static Dao getInstance(...){
        //根据传进来的参数来返回对应的       
        if(...){
           return new JdbcDao();
        }else if(...) {
           return new HibernateDao();
        }
    }
}

然后在service中需要dao的时候,就直接用工厂类的静态方法,根据传递的值,来获取不同的实现类

class TestService {
    Dao dao = DBFactory.getInstance(...);
    public void add(){
       dao.add();
    }
}

【上篇】
【下篇】

抱歉!评论已关闭.