深入浅出工厂模式

简介: 深入浅出工厂模式

工厂模式属于二十三种设计模式之一,但是我们平时还会听到简单工厂和抽象工厂,而它们又与工厂模式有什么异同呢?接下来解释下:

工厂模式、简单工厂模式、抽象工厂模式异同

  • 工厂模式和抽象工厂模式属于二十三种设计模式的创建型模式,而简单工厂模式则不属于二十三种设计模式。
  • 工厂模式不使用new创建对象,而是使用Factory模式;简单工厂模式是通过FW模式来建立对象;抽象工厂模式使用迭代模式来创建对象
  • 工厂模式在使用时可以随时设置变量,不用提前进行设置。简单工厂模式中需要使用参数或者配置文件等已经定义好的变量,然后才能进行下一步的操作。抽象工厂模式则则需要每次增加产品时,进行修改类方法。
  • 工厂模式可以使用两个接口以及三个接口,简单工厂模式只可以使用一个接口。抽象工厂模式可以使用无限个接口。

1 简单工厂模式

     简单工厂(Simple Factory Pattern),工厂模式定义:提供创建对象的接口。

     简单工厂模式(Simple Factory Pattern)属于类的创建型模式,又叫静态工厂方法模式(Static FactoryMethod Pattern),是通过专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类。

网络异常,图片无法展示
|


/**
 * @author 17122
 */
public  class SimpleFactory {
    public static void main(String[] args) {
        Cake cake = CakeFactory.getCake(CakeSort.FRUIT);
        cake.canEat();
        cake.makeCake();
    }
}
interface Cake {
    /**
     * 吃蛋糕
     */
    void canEat();
    /**
     * 做蛋糕
     */
    void makeCake();
}
class MilkCake implements Cake {
    @Override
    public void canEat() {
        System.out.println("Eat MilkCake");
    }
    @Override
    public void makeCake() {
        System.out.println("Make MilkCake");
    }
}
class FruitCake implements Cake {
    @Override
    public void canEat() {
        System.out.println("Eat FruitCake");
    }
    @Override
    public void makeCake() {
        System.out.println("Make FruitCake");
    }
}
class ButterCake implements Cake {
    @Override
    public void canEat() {
        System.out.println("Eat ButterCake");
    }
    @Override
    public void makeCake() {
        System.out.println("Make ButterCake");
    }
}
class CakeFactory {
    /**
     * 获取产物
     *
     * @param sort
     * @return
     */
    public static Cake getCake(String sort) {
        if (CakeSort.FRUIT.equals(sort)) {
            return new FruitCake();
        } else if (CakeSort.BUTTER.equals(sort)) {
            return new ButterCake();
        } else if (CakeSort.MILK.equals(sort)) {
            return new MilkCake();
        }
        return null;
    }
}
class CakeSort {
    public static String FRUIT = "fruit";
    public static String MILK = "milk";
    public static String BUTTER = "butter";
}
复制代码


2 工厂方法模式

     工厂模式(Factory Pattern)是我们最常用的实例化对象模式了,是用工厂方法代替new操作的一种模式。著名的Jive论坛 ,就大量使用了工厂模式,工厂模式在Java程序系统可以说是随处可见。因为工厂模式就相当于创建实例对象的new,我们经常要根据类Class生成实例对象,如A a=new A() 工厂模式也是用来创建实例对象的,所以以后new时就要多个心眼,是否可以考虑使用工厂模式,虽然这样做,可能多做一些工作,但会给你系统带来更大的可扩展性和尽量少的修改量。

网络异常,图片无法展示
|


/**
 * @author 17122
 */
public class Factory {
    public static void main(String[] args) {
        Cakes cake = CakesFactory.getCake(CakeSort.FRUIT);
        cake.setSweetness(1);//使用时随时设置变量
        cake.canEat();
        cake.makeCake();
        System.out.println(cake.sweetness);
    }
}
abstract class Cakes {
    /**
     * 甜度
     */
    public Integer sweetness;
    /**
     * 吃蛋糕
     */
    abstract void canEat();
    /**
     * 做蛋糕
     */
    abstract void makeCake();
    public void setSweetness(Integer s) {
        this.sweetness = s;
    }
}
class MilkCakes extends Cakes {
    @Override
    public void canEat() {
        System.out.println("Eat MilkCake");
    }
    @Override
    public void makeCake() {
        System.out.println("Make MilkCake");
    }
}
class FruitCakes extends Cakes  {
    @Override
    public void canEat() {
        System.out.println("Eat FruitCake");
    }
    @Override
    public void makeCake() {
        System.out.println("Make FruitCake");
    }
}
class ButterCakes extends Cakes {
    @Override
    public void canEat() {
        System.out.println("Eat ButterCake");
    }
    @Override
    public void makeCake() {
        System.out.println("Make ButterCake");
    }
}
class CakesFactory {
    /**
     * 获取产物
     *
     * @param sort
     * @return
     */
    public static Cakes getCake(String sort) {
        if (CakeSort.FRUIT.equals(sort)) {
            return new FruitCakes();
        } else if (CakeSort.BUTTER.equals(sort)) {
            return new ButterCakes();
        } else if (CakeSort.MILK.equals(sort)) {
            return new MilkCakes();
        }
        return null;
    }
}
复制代码


3 抽象工厂模式

     抽象工厂模式(Abstract Factory Pattern)隶属于设计模式中的创建型模式,用于产品族的构建。抽象工厂是所有形态的工厂模式中最为抽象和最具一般性的一种形态。抽象工厂是指当有多个抽象角色时使用的一种工厂模式。抽象工厂模式可以向客户端提供一个接口,使客户端在不必指定产品的具体情况下,创建多个产品族中的产品对象。

     工厂模式中的每一个形态都是针对一定问题的解决方案,工厂方法针对的是多个产品系列结构;而抽象工厂模式针对的是多个产品族结构,一个产品族内有多个产品系列。

具体讲解待补充…


相关文章
|
4天前
|
云安全 监控 安全
|
2天前
|
存储 机器学习/深度学习 人工智能
打破硬件壁垒!煎饺App:强悍AI语音工具,为何是豆包AI手机平替?
直接上干货!3000 字以上长文,细节拉满,把核心功能、使用技巧和实测结论全给大家摆明白,读完你就知道这款 “安卓机通用 AI 语音工具"——煎饺App它为何能打破硬件壁垒?它接下来,咱们就深度拆解煎饺 App—— 先给大家扒清楚它的使用逻辑,附上“操作演示”和“🚀快速上手不踩坑 : 4 条核心操作干货(必看)”,跟着走零基础也能快速上手;后续再用真实实测数据,正面硬刚煎饺 App的语音助手口令效果——创建京东「牛奶自动下单神器」口令 ,从修改口令、识别准确率到场景实用性,逐一测试不掺水,最后,再和豆包 AI 手机语音助手的普通版——豆包App对比测试下,简单地谈谈煎饺App的能力边界在哪?
|
9天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1165 7
|
11天前
|
机器学习/深度学习 人工智能 数据可视化
1秒生图!6B参数如何“以小博大”生成超真实图像?
Z-Image是6B参数开源图像生成模型,仅需16GB显存即可生成媲美百亿级模型的超真实图像,支持中英双语文本渲染与智能编辑,登顶Hugging Face趋势榜,首日下载破50万。
735 42
|
15天前
|
人工智能 Java API
Java 正式进入 Agentic AI 时代:Spring AI Alibaba 1.1 发布背后的技术演进
Spring AI Alibaba 1.1 正式发布,提供极简方式构建企业级AI智能体。基于ReactAgent核心,支持多智能体协作、上下文工程与生产级管控,助力开发者快速打造可靠、可扩展的智能应用。
1178 41
|
15天前
|
人工智能 前端开发 算法
大厂CIO独家分享:AI如何重塑开发者未来十年
在 AI 时代,若你还在紧盯代码量、执着于全栈工程师的招聘,或者仅凭技术贡献率来评判价值,执着于业务提效的比例而忽略产研价值,你很可能已经被所谓的“常识”困住了脚步。
942 78
大厂CIO独家分享:AI如何重塑开发者未来十年
|
3天前
|
人工智能 安全 前端开发
AgentScope Java v1.0 发布,让 Java 开发者轻松构建企业级 Agentic 应用
AgentScope 重磅发布 Java 版本,拥抱企业开发主流技术栈。
|
2天前
|
人工智能 JSON 前端开发
为什么你的API文档总是被吐槽?用这份"契约指令"终结前后端战争
本文针对前后端协作中"文档过时、不准确"的痛点,提供了一套实战验证的AI指令。通过强制结构化输入和自检机制,让AI自动生成包含完整参数、JSON示例和多语言代码的标准API契约文档,彻底解决接口沟通难题。
174 112
|
11天前
|
存储 自然语言处理 测试技术
一行代码,让 Elasticsearch 集群瞬间雪崩——5000W 数据压测下的性能避坑全攻略
本文深入剖析 Elasticsearch 中模糊查询的三大陷阱及性能优化方案。通过5000 万级数据量下做了高压测试,用真实数据复刻事故现场,助力开发者规避“查询雪崩”,为您的业务保驾护航。
563 32