【面试】设计模式

8 篇文章 0 订阅

一、问题

1、谈谈你知道的设计模式(*2)?【第14讲】

类别应用目标例子
创建型模式对对象创建过程的各种问题和解决方案的总结工厂模式、单例模式、构建器模式、原型模式
结构型模式针对软件设计结构的总结,关注于类、对象继承、组合方式的实践经验桥接模式、适配器模式、装饰者模式、代理模式、组合模式、外观模式、享元模式
行为型模式从类或对象之间交互、职责划分等角度总结的模式策略模式、解释器模式、命令模式、观察者模式、迭代器模式、模板方法模式、访问者模式

补充:

应用分类中文英文
创建型模式工厂模式Factory、Abstract Factory
单例模式Singleton
构建器模式Builder
原型模式ProtoType
结构型模式桥接模式Bridge
适配器模式)Adapter
装饰者模式Decorator
代理模式Proxy
组合模式Composite
外观模式Facade
享元模式Flyweight
行为型模式策略模式Strategy
解释器模式Interpreter
命令模式Command
观察者模式Observer
迭代器模式Iterator
、模板方法模式Template Method
访问者模式Visitor
追问1:最常用哪种设计模式?

答:单例模式,工厂方法,抽象工厂,策略模式,观察者模式,代理模式……

2、单例模式是什么,请手动实现(*15)

1、含义:一个类只允许创建一个对象(或者叫实例),那这个类就是一个单例类。

2、经典实现方式

1、饿汉式:在类加载期间,就已经将 instance 静态实例初始化好了。

缺点:不支持延迟加载实例。

优点:符合 fail-fast 设计原则(有问题及早暴露),如果资源不够或启动报错(如 JavaPermGen Space OOM)可以立即修复。
public class IdGenerator { 
  private AtomicLong id = new AtomicLong(0);
  private static final IdGenerator instance = new IdGenerator();
  private IdGenerator() {}
  public static IdGenerator getInstance() {
    return instance;
  }
  public long getId() { 
    return id.incrementAndGet();
  }
}

2、懒汉式
优势:相对于饿汉式,支持延迟加载。
缺陷:如果频繁用到会导致频繁加锁、释放锁,以及并发度低等问题,产生性能瓶颈。

public class IdGenerator { 
  private AtomicLong id = new AtomicLong(0);
  private static IdGenerator instance;
  private IdGenerator() {}
  public static synchronized IdGenerator getInstance() {
    if (instance == null) {
      instance = new IdGenerator();
    }
    return instance;
  }
  public long getId() { 
    return id.incrementAndGet();
  }
}

3、双重检测
优点:既支持延迟加载、又支持高并发的单例实现方式。只要 instance 被创建之后,再调用 getInstance() 函数都不会进入到加锁逻辑中。所以,这种实现方式解决了懒汉式并发度低的问题。

public class IdGenerator { 
  private AtomicLong id = new AtomicLong(0);
  private static IdGenerator instance;
  private IdGenerator() {}
  public static IdGenerator getInstance() {
    if (instance == null) {
      synchronized(IdGenerator.class) { // 此处为类级别的锁
        if (instance == null) {
          instance = new IdGenerator();
        }
      }
    }
    return instance;
  }
  public long getId() { 
    return id.incrementAndGet();
  }
}

4、静态内部类:用 Java 的静态内部类来实现单例。
优点:既支持延迟加载,也支持高并发。

public class IdGenerator { 
  private AtomicLong id = new AtomicLong(0);
  private IdGenerator() {}

  private static class SingletonHolder{
    private static final IdGenerator instance = new IdGenerator();
  }
  
  public static IdGenerator getInstance() {
    return SingletonHolder.instance;
  }
 
  public long getId() { 
    return id.incrementAndGet();
  }
}

5、枚举
这种实现方式通过 Java 枚举类型本身的特性,保证了实例创建的线程安全性和实例的唯一性。

public enum IdGenerator {
  INSTANCE;
  private AtomicLong id = new AtomicLong(0);
 
  public long getId() { 
    return id.incrementAndGet();
  }
}
追问1:有哪些应用场景?

资源访问冲突、表示全局唯一类(配置信息类、唯一递增 ID 号码生成器)

3、Spring 等框架中使用了哪些模式?动态代理实现原理?

……

追问1:Spring 等框架中使用了哪些模式?动态代理实现原理?

……

二、……

三、参考

1、【设计模式】单例模式详解(一)
2、为什么使用枚举实现单例模式,有什么好处_@fall out boy的博客-程序员宅基地_单例模式枚举实现优势

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值