工厂模式设计

转载

https://blog.csdn.net/llussize/article/details/80276627
总体来说,工厂模式适合:凡是出现了大量的产品需要创建,并且具有共同的接口时,可以通过工厂方法模式进行创建。在以上的三种模式中,第一种如果传入的字符串有误,不能正确创建对象,第三种相对于第二种,不需要实例化工厂类,所以,大多数情况下,我们会选用第三种——静态工厂方法模式。

单一工厂模式

package org.example.dao;


//单一工厂方法模式
public class SimpleFactory {
    public static void main(String[] args) {
        SenderFactory senderFactory = new SenderFactory();
        Sender sender = senderFactory.product("Sms");
        sender.send();

        Sender sender2 = senderFactory.product("Mail");
        sender2.send();

        Sender sender3 = senderFactory.product("sms");
        if(sender3==null){
            System.out.println("cuowu");
        }

    }

}
interface  Sender{
    void send();
}
class MailSender implements Sender{
    @Override
    public void send() {
        System.out.println("Mail send message!");
    }
}
class SmsSender implements Sender{
    @Override
    public void send() {
        System.out.println("Sms send message!");
    }
}
class SenderFactory{
    public Sender product(String str){
        if(str.equals("Sms")){
            return new SmsSender();
        }
        else if(str.equals("Mail")){
            return new MailSender();
        }else {
            return null;
        }
    }
}

多工厂方法模式

package org.example.dao;
//多个工厂方法模式

public class MutilFactory2 {
    public static void main(String[] args) {
        Factory factory = new Factory();
        factory.productMailSender().send();
        factory.productSmsSender().send();
    }
}

class Factory {
    public Sender productMailSender(){
        return new MailSender();
    }
    public Sender productSmsSender(){
        return new SmsSender();
    }
}

静态工厂方法模式

package org.example.dao;
//静态工厂方法模式

public class StaticFactory3 {
    public static void main(String[] args) {
        StaticFactory.productMail().send();
        StaticFactory.productSms().send();
    }

}
class StaticFactory{

    public static Sender productMail(){
        return new MailSender();
    }
    public static Sender productSms(){
        return new SmsSender();
    }
}

抽象工厂方法模式(扩展性好)

这个模式的好处就是,如果你现在想增加一个功能:发及时信息,则只需做一个实现类,实现Sender接口,同时做一个工厂类,实现Provider接口,就OK了,无需去改动现成的代码。这样做,拓展性较好!

package org.example.dao;

//抽象工厂模式

public class AbstractFactory {
    public static void main(String[] args) {
        Provider provider = new SendMailFactory();
        Senderr senderr = provider.product();
        senderr.send();
        Provider provider2 = new SendSmsFactory();
        Senderr senderr2 = provider2.product();
        senderr2.send();
    }

}

interface Senderr {
    void send();
}

class Mail implements Senderr {
    @Override
    public void send() {
        System.out.println("Mail send message!");
    }
}

class Sms implements Senderr {
    @Override
    public void send() {
        System.out.println("Sms send message!");
    }
}

//提供一个接口
interface Provider {
    public Senderr product();
}

//两个工厂类
class SendMailFactory implements Provider {
    @Override
    public Senderr product() {
        return new Mail();
    }
}

class SendSmsFactory implements Provider {
    @Override
    public Senderr product() {
        return new Sms();
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值