文章目录
其实工厂模式就是用一个代理类帮你创建管理对象,你就不用在代码层面去不断new对象的使用了。
创建对象和调用对象两者之间会解耦!
定义
工厂模式有三种:
- 简单工厂模式
- 工厂方法模式
- 抽象方法模式
简单工厂模式
简单工厂模式也叫静态工厂模式。
举个例子:你要去买一台手机,你不用关心手机是怎么生产出来的,里面的零件具体又是怎么制造的,这些通通都交给工厂去处理,你尽管去买手机就好了。
案例 | 代码
Phone顶层接口设计
/**
* @author linghu
* @date 2024/7/5 11:08
*/
public interface Phone {
void getBrand();
}
Meizu品牌类
/**
* @author linghu
* @date 2024/7/5 11:09
*/
public class Meizu implements Phone{
@Override
public void getBrand() {
System.out.println("魅族");
}
}
Xiaomi品牌类
/**
* @author linghu
* @date 2024/7/5 12:35
*/
public class Xiaomi implements Phone{
@Override
public void getBrand() {
System.out.println("小米");
}
}
PhoneFactory工厂类
这个是简单工厂模式,又叫静态工厂,所以方法自然是静态的!而且这个工厂类负责帮我们创建对象,并且返回对象!
在这里我们可以先用硬编码的方式:
/**
* @author linghu
* @date 2024/7/5 12:35
*/
public class PhoneFactory {
public static Phone getPhone(String phone){
if ("小米".equals(phone)){
return new Xiaomi();
} else if ("魅族".equals(phone)) {
return new Meizu();
}else {
return null;
}
}
}
Customer 消费者类
这个类就类似一个客户端的作用把。
/**
* @author linghu
* @date 2024/7/5 12:38
*/
public class Customer {
public static void main(String[] args) {
PhoneFactory.getPhone("小米").getBrand();
PhoneFactory.getPhone("魅族").getBrand();
}
}
工厂方法模式
工厂方法模式就是在上面简单工厂模式的基础上做了一些修改,具体的做法就是为每种不同品牌的手机都创建一个工厂独立生产。
案例 | 代码
如上,其他代码都不变,变化的部分是工厂那部分!
PhoneFactory工厂类
首先修改一下PhoneFactory工厂类,将:
/**
* @author linghu
* @date 2024/7/5 12:35
*/
public class PhoneFactory {
public static Phone getPhone(String phone){
if ("小米".equals(phone)){
return new Xiaomi();
} else if ("魅族".equals(phone)) {
return new Meizu();
}else {
return null;
}
}
}
修改为:
/**
* @author linghu
* @date 2024/7/5 12:35
*/
public interface PhoneFactory {
Phone getPhone();
}
新增的两个工厂类:
/**
* @author linghu
* @date 2024/7/5 14:09
*/
public class MeizuFactory implements PhoneFactory{
@Override
public Phone getPhone() {
return new Meizu();
}
}
/**
* @author linghu
* @date 2024/7/5 14:08
*/
public class XiaomiFactory implements PhoneFactory{
@Override
public Phone getPhone() {
return new Xiaomi();
}
}
Customer 消费者类:
/**
* @author linghu
* @date 2024/7/5 12:38
*/
public class Customer {
public static void main(String[] args) {
// PhoneFactory.getPhone("小米").getBrand();
// PhoneFactory.getPhone("魅族").getBrand();
Phone xiaomi=new XiaomiFactory().getPhone();
Phone meizu=new MeizuFactory().getPhone();
xiaomi.getBrand();
meizu.getBrand();
}
}
Java高级特性—工厂模式与反射的高阶玩法
我们先回顾一下上面的工厂模式用法,列举一下会发现:
- 简单工厂模式的局限性在于:如果我们扩充手机的品牌,就会违反 开闭原则。
- 工厂方法模式的局限性在于:我们扩充手机品牌需要不断new更多对象,这是耦合的最大元凶!!
方案:反射+工厂模式
PhoneFactory工厂类
/**
* @author linghu
* @date 2024/7/5 12:35
*/
public class PhoneFactory {
public static Phone getInstance(String origin) throws ClassNotFoundException, InstantiationException, IllegalAccessException {
Class<?> cls = Class.forName("com.linghu.factory." + origin);
Phone brand=(Phone)cls.newInstance();
return brand;
}
}
Customer 消费者类
这个时候我们无需再new更多对象了,也不用写死了:
/**
* @author linghu
* @date 2024/7/5 12:38
*/
public class Customer {
public static void main(String[] args) throws ClassNotFoundException, InstantiationException, IllegalAccessException {
// PhoneFactory.getPhone("小米").getBrand();
// PhoneFactory.getPhone("魅族").getBrand();
// Phone xiaomi=new XiaomiFactory().getPhone();
// Phone meizu=new MeizuFactory().getPhone();
// xiaomi.getBrand();
// meizu.getBrand();
PhoneFactory.getInstance("Xiaomi").getBrand();
}
}
输入类名以后,反射创建对象,再通过工厂返回相关对象!!
总结
第一个静态工厂模式:在实际去开发中会发现比较常用,尽管上面讲了不符合(面向对象)OOP原则。
第二个工厂方法模式:不修改工厂类的前提,也就是说不修改已有类,实现对扩展是开发,对修改关闭。