2、抽象工厂模式(Abstract Factory)
2016-02-04 00:00
267 查看
工 厂方法模式有一个问题就是,类的创建依赖工厂类,也就是说,如果想要拓展程序,必须对工厂类进行修改,这违背了闭包原则,所以,从设计角度考虑,有一定的 问题,如何解决?就用到抽象工厂模式,创建多个工厂类,这样一旦需要增加新的功能,直接增加新的工厂类就可以了,不需要修改之前的代码。因为抽象工厂不太 好理解,我们先看看图,然后就和代码,就比较容易理解。
请看例子:
[java]
public interface Sender {
public void Send();
}
两个实现类:
[java]
public class MailSender implements Sender {
@Override
public void Send() {
System.out.println("this is mailsender!");
}
}
[java]
public class SmsSender implements Sender {
@Override
public void Send() {
System.out.println("this is sms sender!");
}
}
两个工厂类:
[java]
public class SendMailFactory implements Provider {
@Override
public Sender produce(){
return new MailSender();
}
}
[java]
public class SendSmsFactory implements Provider{
@Override
public Sender produce() {
return new SmsSender();
}
}
在提供一个接口:
[java]
public interface Provider {
public Sender produce();
}
测试类:
[java]
public class Test {
public static void main(String[] args) {
Provider provider = new SendMailFactory();
Sender sender = provider.produce();
sender.Send();
}
}
其实这个模式的好处就是,如果你现在想增加一个功能:发及时信息,则只需做一个实现类,实现Sender接口,同时做一个工厂类,实现Provider接口,就OK了,无需去改动现成的代码。这样做,拓展性较好!
请看例子:
[java]
public interface Sender {
public void Send();
}
两个实现类:
[java]
public class MailSender implements Sender {
@Override
public void Send() {
System.out.println("this is mailsender!");
}
}
[java]
public class SmsSender implements Sender {
@Override
public void Send() {
System.out.println("this is sms sender!");
}
}
两个工厂类:
[java]
public class SendMailFactory implements Provider {
@Override
public Sender produce(){
return new MailSender();
}
}
[java]
public class SendSmsFactory implements Provider{
@Override
public Sender produce() {
return new SmsSender();
}
}
在提供一个接口:
[java]
public interface Provider {
public Sender produce();
}
测试类:
[java]
public class Test {
public static void main(String[] args) {
Provider provider = new SendMailFactory();
Sender sender = provider.produce();
sender.Send();
}
}
其实这个模式的好处就是,如果你现在想增加一个功能:发及时信息,则只需做一个实现类,实现Sender接口,同时做一个工厂类,实现Provider接口,就OK了,无需去改动现成的代码。这样做,拓展性较好!
相关文章推荐
- 3、单例模式(Singleton)
- 4、建造者模式(Builder)
- 5、原型模式(Prototype)
- 6、适配器模式(Adapter)
- 7、装饰模式(Decorator)
- 8、代理模式(Proxy)
- 9、外观模式(Facade)
- 10、桥接模式(Bridge)
- 利用before after伪类 制作凹感的直线
- js的匿名函数
- CoreData 使用
- iOS中几种数据持久化方案
- 我的社会媒体账号
- Android应用名 显示为空
- 关于C++野指针的问题
- 解决启动WebLogic输入用户名密码问题 & 密码重置
- 我的2015年终工作总结
- Ubuntu交换CapLock和Esc
- mysql之主从、主主同步
- Linux下查看文件和文件夹大小