【设计模式】Java设计模式 -工厂模式

不断学习才是王道

继续踏上学习之路,学之分享笔记

总有一天我也能像各位大佬一样

一个有梦有戏的人 @怒放吧德德

分享学习心得,欢迎指正,大家一起学习成长!

简介

在大多情况下,我们都是用new去实例化对象。但是,有时候有的对象的类别有很多种,又存在着共性,就好比如汽车,有奔驰,红旗,宝马等品牌,如果是一个一个去创建类,那就需要创建很多,因此就需要用到工厂模式。

1、普通工厂(Simple Factory)模式

在简单工厂模式中,可以根据参数的不同返回不同类的实例。简单工厂模式专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类。

UML如图:

①、定义类

首先定义一个汽车抽象类

package com.lyd.demo.entity;

/**
* @Author: lyd
* @Description: 产品实体
* @Date: 2022-08-21
*/
public abstract class ICar {
protected String name; public ICar(String name) {
this.name = name;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public abstract void contract(); public void pickUp() {
System.out.println("提车->" + name);
}
}

定义奔驰汽车类和红旗汽车类。并且继承基类

奔驰:

package com.lyd.demo.entity;

/**
* @Author: lyd
* @Description: 奔驰汽车类
* @Date: 2022-08-21
*/
public class BenzCar extends ICar {
public BenzCar(String name) {
super(name);
} public void contract() {
System.out.println("奔驰旗舰店和客户签订合同");
}
}

红旗类与奔驰类似,这里就不贴冗余代码了

②、定义简单的工厂类

工厂类:

package com.lyd.demo.simpleFactory;

import com.lyd.demo.entity.BenzCar;
import com.lyd.demo.entity.HongQiCar;
import com.lyd.demo.entity.ICar; import javax.naming.NotContextException; /**
* @Author: lyd
* @Description: 普通工厂模式
* @Date: 2022-08-20
*/
public class CarFactory {
public static ICar createCar(String carId) throws NotContextException {
switch (carId) {
case "1": return new BenzCar("奔驰GLA");
case "2": return new HongQiCar("红旗H7");
default: throw new NotContextException("没有该编号的汽车");
}
}
}

③、实例

测试实验

对调用者来说,就只需要知道createCar方法,指定汽车的编号就可以实例化出对应的对象

package com.lyd.demo.test;

import com.lyd.demo.entity.ICar;
import com.lyd.demo.simpleFactory.CarFactory; import javax.naming.NotContextException; /**
* @Author: lyd
* @Description: 测试类
* @Date: 2022-08-21
*/
public class SimpleFactoryTest {
public static void main(String[] args) throws NotContextException {
ICar car = CarFactory.createCar("1");
car.contract();
car.pickUp();
}
}

运行结果:

2、抽象工厂(Abstract Factory)模式

抽象工厂模式提供一个接口,不必去指定具体的产品,创建多个产品族的产品对象。对于普通的工厂来说,可以解决一类对象的创建,但是对象有时候很复杂,在有几十种对象中又分了好几种类型,只有一个工厂的话,实现起来就十分复杂,因此需要吧工厂分为很多种,就比如汽车中有奔驰、红旗等,在奔驰中又分为了A级C级等,这就可以吧奔驰,红旗创建各自的工厂,由工厂来划分是具体哪个对象。

UML如图:

①、定义类

采用以上的Icar抽象类,本次定义了四个类:BenzGLA、BenzGLB、HongQiH5、HongQiH7

package com.lyd.demo.car.entity.benz;

import com.lyd.demo.car.entity.ICar;

/**
* @Author: lyd
* @Description: 奔驰GLA
* @Date: 2022-08-21
*/
public class BenzGLA extends ICar {
public BenzGLA(String name) {
super(name);
} public void contract() {
System.out.println("奔驰旗舰店和客户签订合同-购买->" + name);
}
}

其他类都一样,就不一个一个粘贴

②、定义工厂接口

ICarFactory:

只提供一个创建产品的接口

package com.lyd.demo.car.factory;

import com.lyd.demo.car.entity.ICar;

/**
* @Author: lyd
* @Description: 汽车工厂
* @Date: 2022-08-21
*/
public interface ICarFactory {
public ICar createProduct(String CarNo);
}

定义奔驰和红旗的工厂类

两个工厂类也都是差不多,需要实现ICarFactory,并且实现具体方法,在此方法来根据需要生成对应的对象。

package com.lyd.demo.car.factory.impl;

import com.lyd.demo.car.entity.ICar;
import com.lyd.demo.car.entity.benz.BenzGLA;
import com.lyd.demo.car.entity.benz.BenzGLB;
import com.lyd.demo.car.factory.ICarFactory; /**
* @Author: lyd
* @Description: 奔驰汽车的工厂类
* @Date: 2022-08-21
*/
public class BenzFactory implements ICarFactory {
public ICar createProduct(String CarNo) {
System.out.println("奔驰工厂");
ICar car = null;
// 根据id创建产品
if (CarNo.equals("GLA")) {
// 生成GLA型号的奔驰汽车
car = new BenzGLA(CarNo);
} else if (CarNo.equals("GLB")) {
// 生成GLB型号的奔驰汽车
car = new BenzGLB(CarNo);
}
if (car != null) return car;
return null;
}
}

红旗的工厂类同

汽车工厂类:

根据一定的逻辑(本次实验根据编号)来生成对应的工厂,在由工厂去判断实例化哪个对象。

package com.lyd.demo.car.factory.impl;

import com.lyd.demo.car.entity.ICar;
import com.lyd.demo.car.factory.ICarFactory; /**
* @Author: lyd
* @Description: 汽车工厂
* @Date: 2022-08-21
*/
public class CarFactory implements ICarFactory {
public ICar createProduct(String CarNo) {
ICarFactory factory = null;
if (CarNo.equals("GLA") || CarNo.equals("GLB")) { // 如果是奔驰的品牌
factory = new BenzFactory();
} else {
factory = new HongQiFactory();
}
if (factory != null) {
return factory.createProduct(CarNo);
}
return null;
}
}

③、实例

测试抽象工厂模式

package com.lyd.demo.test;

import com.lyd.demo.car.entity.ICar;
import com.lyd.demo.car.factory.impl.CarFactory; /**
* @Author: lyd
* @Description: 测试类
* @Date: 2022-08-21
*/
public class ProductTest {
public static void main(String[] args) {
CarFactory factory = new CarFactory();
ICar car = factory.createProduct("GLA");
car.contract();
}
}

运行结果:

【设计模式】Java设计模式 -工厂模式的更多相关文章

  1. Java进阶篇设计模式之二 ----- 工厂模式

    前言 在上一篇中我们学习了单例模式,介绍了单例模式创建的几种方法以及最优的方法.本篇则介绍设计模式中的工厂模式,主要分为简单工厂模式.工厂方法和抽象工厂模式. 简单工厂模式 简单工厂模式是属于创建型模 ...

  2. Java设计模式之【工厂模式】(简单工厂模式,工厂方法模式,抽象工厂模式)

    Java设计模式之[工厂模式](简单工厂模式,工厂方法模式,抽象工厂模式) 工厂模式出现的原因 在java中,创建一个对象最简单的方法就是使用new关键字.但在一些复杂的业务逻辑中,创建一个对象不只需 ...

  3. Java设计模式之二 ----- 工厂模式

    在上一篇中我们学习了单例模式,介绍了单例模式创建的几种方法以及最优的方法.本篇则介绍设计模式中的工厂模式,主要分为简单工厂模式.工厂方法和抽象工厂模式. 简单工厂模式 简单工厂模式是属于创建型模式,又 ...

  4. Java 设计模式之抽象工厂模式(三)

    原文地址:Java 设计模式之抽象工厂模式(三) 博客地址:http://www.extlight.com 一.前言 上篇文章 <Java 设计模式之工厂模式(二)>,介绍了简单工厂模式和 ...

  5. Java设计模式之二工厂模式

    在上一篇中我们学习了单例模式,介绍了单例模式创建的几种方法以及最优的方法.本篇则介绍设计模式中的工厂模式,主要分为简单工厂模式.工厂方法和抽象工厂模式. 简单工厂模式 简单工厂模式是属于创建型模式,又 ...

  6. java设计模式---三种工厂模式

    工厂模式提供创建对象的接口. 工厂模式分为三类:简单工厂模式(Simple Factory), 工厂方法模式(Factory Method)和抽象工厂模式(Abstract Factory).GOF在 ...

  7. 设计模式-Runoob:工厂模式

    ylbtech-设计模式-Runoob:工厂模式 1.返回顶部 1. 工厂模式 工厂模式(Factory Pattern)是 Java 中最常用的设计模式之一.这种类型的设计模式属于创建型模式,它提供 ...

  8. 乐在其中设计模式(C#) - 抽象工厂模式(Abstract Factory Pattern)

    原文:乐在其中设计模式(C#) - 抽象工厂模式(Abstract Factory Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 抽象工厂模式(Abstract Factor ...

  9. 桥接模式及C++实现 C++设计模式-AbstractFactory抽象工厂模式

    桥接模式及C++实现 桥接模式 先说说桥接模式的定义:将抽象化(Abstraction)与实现化(Implementation)分离,使得二者可以独立地变化. 桥接模式号称设计模式中最难理解的模式之一 ...

  10. C#设计模式(2)-简单工厂模式

    引言 上一遍中介绍了设计模式中的单例模式-C#设计模式(1)-单例模式,本篇将介绍简单工厂模式,也是比较容易理解的一种模式: 简单工厂模式简介 什么是简单工厂模式? 定义一个工厂类,它可以根据参数的不 ...

随机推荐

  1. 爬虫(9) - Scrapy框架(1) | Scrapy 异步网络爬虫框架

    什么是Scrapy 基于Twisted的异步处理框架 纯python实现的爬虫框架 基本结构:5+2框架,5个组件,2个中间件 5个组件: Scrapy Engine:引擎,负责其他部件通信 进行信号 ...

  2. Intel的CPU系列说明

    至强可扩展系列是英特尔推出的新一代至强处理器系列,如今距离该系列推出几乎过去一年了.新的CPU并没有延续E系列的命名,英特尔将至强可扩展系列以金属命名,将该系列分为"铂金Platinum&q ...

  3. resultMap自定义映射(一对多)

    collection:处理一对多和多对多的关系 1) POJO中的属性可能会是一个集合对象,我们可以使用联合查询,并以级联属性的方式封装对象.使用collection标签定义对象的封装规则 publi ...

  4. Mvcapi解决H5请求接口跨域问题

    using Newtonsoft.Json;using System;using System.Collections.Generic;using System.Linq;using System.N ...

  5. 2022-07-11 第六组 润土 JavaScript01学习笔记

    1.JS的数据类型: 数字 字符串 布尔型 空(null) unefined(未定义) 2.定义变量 var let(不可重复) const(常量不可更改) 3.复杂的数据类型: 数组:一个变量对应多 ...

  6. super详解(继承)

    //在Java中,所有的类,都默认直接或者间接继承objec类// Person 人 :父类public class Person /*extends object*/ { public Person ...

  7. HCNP Routing&Switching之DHCP中继

    前文我们聊了下BFD相关话题,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/16487842.html:今天来聊一聊DHCP中继相关话题: DHCP的作用 DH ...

  8. C#异步延迟Task.Delay

    一. 1.Task.Delay实质是创建一个任务,再任务中开启一个定时间,然后延时指定的时间2.Task.Delay不和await一起使用情况,当代码遇到Task.Delay一句时,创建了了一个新的任 ...

  9. mysql 之full join

    首先,mysql中是不支持full join的,如果要实现类似的功能可以用union all,union会剔除重复.以下是实现实例 create table if not exists t1(`id` ...

  10. linux rz上传失败

    最近rz上传文件时出现了一次文件上传失败的情况,故搜集了以下资料加强学习 rz -ary --o-sync -a 表示使用ascii码格式传输文件,如果是Dos格式的文件,会转换为unix格式 -r ...