JAVA工厂模式全网最详细说明

JAVA工厂模式全网最详细说明

假如说现在有一个食物生产工厂,当有人需要食物得时候就会生产相应的食物。这个我们应该怎么去做呢?

 interface Food {//定义一个食物标准
	public void eat();
}
class Bread implements Food{
	@Override
	public void eat() {
		System.out.println("吃面包");
	}
}

class beef implements Food {
	@Override
	public void eat() {
		System.out.println("吃牛肉");
	}
}
public class Javademo {
	public static void main(String[] args) {
		Food food1 = new beef;
		food1.eat();
	}

普通工厂模式
我们去写一个接口,让食物类都去实现这个接口,需要那种食物就创建那种食物的对象。但这个时候弊病就很明显了。客户只是对食物加工有一个模糊的概念,他们只知道有这么一个食物的工厂可以生产食物,这样的代码对客户很不友好。而且new关键词造成了代码的耦合性,
如果现在还想吃其他食物还要去创建对象。这时候我们应该就要想到有没有什么办法能把这些食物整合起来,交给一个工厂去加工,用户只用去关心食物本身就可以了。这就是我们的普通工厂模式:


 interface Food {//定义一个食物标准
	public void eat();
}
class Bread implements Food{

	@Override
	public void eat() {
		System.out.println("吃面包");
	}
}

class beef implements Food {

	@Override
	public void eat() {
		System.out.println("吃牛肉");
		
	}
	
}
class Factory {
	public static Food addFood(String foodname) {
		if("bread".equals(foodname)) {
			return new Bread();
		}else if("beef".equals(foodname)){
			return new beef();
		}
		
		return null;
	}
}
public class Javademo {
	public static void main(String[] args) {
		Food food1 = Factory.addFood("beef");
		food1.eat();
	}
}

抽象工厂模式
这样一来就解决了我们代码耦合性的问题。用户吃什么就去通过这个工厂去加工,不用去一个一个创建在去调用,提高了用户体验,增加了代码的复用性,减少了代码耦合。但现实中可能情况更加复杂,生产牛肉和面包的会在一个工厂么,面包属于点心,牛肉属于肉质品,处理的方式不同,当然要交给不同的工厂去处理。这时候我们需要一个工厂的接口让所有的食物工厂去实现这个接口,食物工厂再去生产食物。用户只需要记住那个编号的工厂能生产那种食物即可。我们叫这种模式称为抽象:’工厂模式’;

package aaa;

interface Food{
	void eat();
}
interface publicfactory {
 	  Food madefood(String foodname/*食物名称*/);
}
/*牛肉*/
class beef implements Food{
	@Override
	public void eat() {
		System.out.println("正在吃牛肉");
	}
}
/*猪肉*/
class pork implements Food{
	@Override
	public void eat() {
		System.out.println("正在吃猪肉");
	}
}
/*面包*/
class bread implements Food{
	@Override
	public void eat() {
		System.out.println("正在吃面包");	
	}
}
/*蛋糕*/
class cake implements Food{
	@Override
	public void eat() {
		System.out.println("正在吃蛋糕");	
	}
}
/*食物生产厂1只生产点心*/
class factory1 implements publicfactory{
	@Override
	public Food madefood(String foodname) {
		if("bread".equals(foodname)) {
			return new bread();
		}else if("cake".equals(foodname)) {
			return new cake();
		}
		return null;
	}
}
/*食物生产厂2只生产肉类*/
class factory2 implements publicfactory{
	@Override
	public Food madefood(String foodname) {
		if("beef".equals(foodname)) {
			return new beef();
		}else if("cake".equals(foodname)) {
			return new pork();
		}
		return null;
	}
}
/*食物工厂类公共类*/
class creatfactory{
	public static publicfactory creat(String foodfactory) {
		if("1".equals(foodfactory)) {
			return new factory1();
		}else if("2".equals(foodfactory)){
			return new factory2();
		}
		return null;
	}
}
public class Javademo2 {
	public static void main(String[] args) {
		/*用户直接通过工厂编号去调用工厂生产食物*/
		Food food = creatfactory.creat("1").madefood("bread");
		food.eat();
	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值