博客
关于我
菜鸟的java设计模式学习总结
阅读量:746 次
发布时间:2019-03-22

本文共 5152 字,大约阅读时间需要 17 分钟。

菜鸟的Java设计模式学习总结

菜鸟的Java设计模式学习总结

单例模式

单例模式通过确保一个类只创建一个实例来优化资源使用。饿汉式和饥汉式仅在于实例化时机不同,但核心思想相同。

实现

public class SingleObject {    private static SingleObject instance = new SingleObject();    private SingleObject() {    }    public static SingleObject getInstance() {        return instance;    }    public void showMessage() {        System.out.println("hello world!");    }}

使用

通过调用Singleton.getInstance()获取唯一实例。

工厂模式

工厂模式通过引入抽象工厂,统一管理对象创建,避免直接暴露实现细节。

实现

public class ShapeFactory {    public Shape getShape(String shapeType) {        if (shapeType == null)            return null;        if (shapeType.equalsIgnoreCase("CIRCLE"))            return new Circle();        else if (shapeType.equalsIgnoreCase("RECTANGLE"))            return new Rectangle();        else if (shapeType.equalsIgnoreCase("SQUARE"))            return new Square();        return null;    }}

使用

// 获取不同形状的实例Shape circle = shapeFactory.getShape("CIRCLE");Shape rectangle = shapeFactory.getShape("RECTANGLE");

代理模式

代理模式允许在不修改目标对象代码的情况下增强功能,分为基于子类和接口动态代理。

基于子类动态代理

public class Producer {    public void saleProduct(float money) {        System.out.println("您好!这里是生产产家的销售...");    }    public void afterService(float money) {        System.out.println("您好,这里是生产产家的售后...");    }}class MyProxy {    public Producer proxy() {        Producer producer = new Producer();        return (Producer) Enhancer.create(            producer.getClass(),            new MethodInterceptor() {                public Object intercept(Object obj, Method method, Object[] args, MethodProxy methodProxy) throws Throwable {                    System.out.println("\t方法被拦截:" + method);                    Object invoke = null;                    if ("saleProduct".equals(method.getName())) {                        invoke = method.invoke(producer, (float) args[0] * 0.8f);                    }                    return invoke;                }            }        );    }}

基于接口动态代理

public interface IProducer {    void saleProduct(float money);    void afterService(float money);}class MyProxy implements InvocationHandler {    private IProducer target;    public MyProxy(IProducer target) {        this.target = target;    }    public void invoke(IProducer target, Method method, Object[] args) throws Throwable {        System.out.println("\t方法被拦截:" + method);        Object invoke = null;        if ("saleProduct".equals(method.getName())) {            invoke = method.invoke(target, (float) args[0] * 0.8f);        }        return invoke;    }}public class Test {    public static void main(String[] args) {        MemoryCard card = new MemoryCard();        Computer computer = new ComputerImpl();        Adapter02 adapter = new Adapter02(card);        computer.getContent();        computer.readContent();    }}

适配者模式

适配者模式通过桥接不兼容的接口,实现系统间互操作。

对象实例适配器

public class MemoryCard {    public String content() {        return "学习资料\n\t--日韩\n\t--欧美\n\t--国产\n\t--主播";    }}public interface Computer {    String getContent();    void readContent();}public class Adapter01 implements Computer {    private MemoryCard memoryCard = new MemoryCard();    public String getContent() {        System.out.println("内存卡内容读取中...");        String content = memoryCard.content();        System.out.println("内存卡内容读取完成...");        return content;    }    public void readContent() {        String content = getContent();        System.out.println("电脑正在输出读取到的内存卡信息...");        System.out.println("\n电脑读取到的内容:\n" + content);    }}

类适配器

public class Adapter02 extends MemoryCard implements Computer {    public String getContent() {        System.out.println("内存卡内容读取中...");        String content = super.content();        System.out.println("内存卡内容读取完成...");        return content;    }    public void readContent() {        String content = getContent();        System.out.println("电脑正在输出读取到的内存卡信息...");        System.out.println("\n电脑读取到的内容:\n" + content);    }}

建造者模式

建造者模式将对象的构建过程分解为独立的步骤,便于管理复杂对象的创建。

实现

public interface IBuilder {    void buildGround();    void buildGroundBeam();    void buildFixture();    void buildCement();    void buildRoof();    House getHouse();}public class DefaultBuilder implements IBuilder {    protected House house = new House();    public DefaultBuilder() {        this.house = new House();    }    @Override    public void buildGround() {        house.setGround("打地基完成");    }    @Override    public void buildGroundBeam() {        house.setGroundBeam("地梁施工完成");    }    @Override    public void buildFixture() {        house.setFixture("钢筋施工完成");    }    @Override    public void buildCement() {        house.setCement("水泥施工完成");    }    @Override    public void buildRoof() {        house.setRoof("屋顶施工完成");    }    @Override    public House getHouse() {        return house;    }}public class Director {    public static House create(IBuilder builder) {        builder.buildGround();        builder.buildGroundBeam();        builder.buildFixture();        builder.buildCement();        builder.buildRoof();        return builder.getHouse();    }}

使用

House house = Director.create(new DefaultBuilder());

总结

这些设计模式在软件开发中发挥着重要作用,了解它们的特点和适用场景有助于有效地解决实际问题。通过不断学习和实践,可以更好地掌握这些模式并灵活运用以优化代码质量。

转载地址:http://xomwk.baihongyu.com/

你可能感兴趣的文章
logstash mysql 准实时同步到 elasticsearch
查看>>
Luogu2973:[USACO10HOL]赶小猪
查看>>
mabatis 中出现< 以及> 代表什么意思?
查看>>
Mac book pro打开docker出现The data couldn’t be read because it is missing
查看>>
MAC M1大数据0-1成神篇-25 hadoop高可用搭建
查看>>
mac mysql 进程_Mac平台下启动MySQL到完全终止MySQL----终端八步走
查看>>
Mac OS 12.0.1 如何安装柯美287打印机驱动,刷卡打印
查看>>
MangoDB4.0版本的安装与配置
查看>>
Manjaro 24.1 “Xahea” 发布!具有 KDE Plasma 6.1.5、GNOME 46 和最新的内核增强功能
查看>>
mapping文件目录生成修改
查看>>
MapReduce程序依赖的jar包
查看>>
mariadb multi-source replication(mariadb多主复制)
查看>>
MariaDB的简单使用
查看>>
MaterialForm对tab页进行隐藏
查看>>
Member var and Static var.
查看>>
memcached高速缓存学习笔记001---memcached介绍和安装以及基本使用
查看>>
memcached高速缓存学习笔记003---利用JAVA程序操作memcached crud操作
查看>>
Memcached:Node.js 高性能缓存解决方案
查看>>
memcache、redis原理对比
查看>>
memset初始化高维数组为-1/0
查看>>