博客
关于我
菜鸟的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/

你可能感兴趣的文章
Nacos和Zookeeper对比
查看>>
Nacos在双击startup.cmd启动时提示:Unable to start embedded Tomcat
查看>>
Nacos基础版 从入门到精通
查看>>
Nacos如何实现Raft算法与Raft协议原理详解
查看>>
Nacos安装教程(非常详细)从零基础入门到精通,看完这一篇就够了
查看>>
Nacos实战攻略:从入门到精通,全面掌握服务治理与配置管理!(上)
查看>>
Nacos实战攻略:从入门到精通,全面掌握服务治理与配置管理!(下)
查看>>
Nacos心跳机制实现快速上下线
查看>>
nacos报错com.alibaba.nacos.shaded.io.grpc.StatusRuntimeException: UNAVAILABLE: io exception
查看>>
nacos服务提供和发现及客户端负载均衡配置
查看>>
Nacos服务注册与发现demo
查看>>
Nacos服务注册与发现的2种实现方法!
查看>>
nacos服务注册和发现原理简单实现案例
查看>>
Nacos服务注册总流程(源码分析)
查看>>
nacos服务注册流程
查看>>
Nacos服务部署安装
查看>>
nacos本地可以,上服务器报错
查看>>
Nacos注册Dubbo(2.7.x)以及namespace配置
查看>>
Nacos注册中心有几种调用方式?
查看>>
nacos注册失败,Feign调用失败,feign无法注入成我们的bean对象
查看>>