1.普通简单工厂
工厂类负责对实现同一接口的类进行实例创建,
关系图如下
代码如下:
package com.designer.factory;
public class SendFactory {
public Sender produce(String type) {
if ("mail".equals(type)) {
return new MailSender();
} else if ("msg".equals(type)) {
return new MsgSender();
} else {
System.out.println("请输入正确的类型");
return null;
}
}
}
package com.designer.factory;
public interface Sender {
public void send();
}
package com.designer.factory;
public class MailSender implements Sender{
@Override
public void send() {
// TODO Auto-generated method stub
System.out.println("this is a mailSender");
}
}
package com.designer.factory;
public class MsgSender implements Sender{
@Override
public void send() {
// TODO Auto-generated method stub
System.out.println("this is a msgSender");
}
}
package com.designer.factory;
public class Test {
public static void main(String[] args) {
Sender send=new SendFactory().produce("msg");
send.send();
}
}
运行结果:
2.多方法简单工厂
普通工厂方法模式中,如果传递的字符串出错,则不能正确创建对象,多方法简单工厂为工厂提供创建每个实例的方法,避免这种问题。
关系图如下
代码如下:
对比这里只有SenderFactory做了改变,这里仅贴出SenderFactory和Test的代码
package com.designer.factory;
public class SendFactory {
public Sender produceMail() {
return new MailSender();
}
public Sender produceMsg(){
return new MsgSender();
}
}
package com.designer.factory;
public class Test {
public static void main(String[] args) {
Sender send=new SendFactory().produceMail();
send.send();
}
}
结果如下:
3.静态方法简单工厂
将上面的多个工厂方法模式里的方法置为静态的,不需要创建实例,直接调用
即将SenderFactory中的produceMail()和produceMsg()改为静态方法。其他文件同样不变
代码如下:
package com.designer.factory;
public class SendFactory {
public static Sender produceMail() {
return new MailSender();
}
public static Sender produceMsg(){
return new MsgSender();
}
}
package com.designer.factory;
public class Test {
public static void main(String[] args) {
Sender send=SendFactory.produceMail();
send.send();
}
}
4.总结
工厂模式的使用场景:
当几个实现类都有相同的接口,可用工厂模式,易于扩展和修改。
工厂模式选择:
以上三种模式,第一种字符串有误会导致异常,第三种由于是静态方法,不需要重复创建对象,所以一般选择第三种——静态工厂方法
5.工厂方法模式
简单工厂模式有一个问题就是,类的创建依赖工厂类,也就是说,如果想要拓展程序,必须对工厂类进行修改。
用工厂方法模式,创建一个工厂接口和创建多个工厂实现类,这样一旦需要增加新的功能,直接增加新的工厂类就可以了,不需要修改之前的代码
关系图如下:
具体的实现这里就不再写出来了,只是给MailSenderFactory和MsgSenderFactory提供一格接口,让工厂类也易于扩展。
这个模式的好处
如果你现在想增加一个功能:发及时信息,则只需做一个实现类,实现Sender接口,同时做一个工厂类,实现Provider接口,就OK了,无需去改动现成的代码。这样做,拓展性较好!