记录一次单例模式乱用带来的危害。

项目场景:

我们在接受到短信网关下发的回执之后,需要将回执内容也下发给我们的下游服务。为了防止下游响应超时,我们需要将超时的信息存放到Redis中然后进行补发操作。


问题描述

在使用Redis进行数据存储的时候,报NPE问题。


原因分析:

在Spring托管的Bean中手动通过单例模式的方式去构造了实体对象,导致Bean对象不受Spring托管,无法通过Autowried的注入方式进行注入。

代码示例如下:

java 复制代码
@Component
public class ApplicationInitor {
      @Autowired
      private UserService userService;

      public static ApplicationInitor getApplicationInitor(){
        return Inner.instance;
      }

      private static class Inner {
        private static final ApplicationInitor instance = new ApplicationInitor();
      }

    public void register(String name) {
        try {
            TestDemo testDemo = new TestDemo(userService);
            testDemo.registerUser(name);
        }catch (Exception e) {
            e.printStackTrace();
        }
    }

    class TestDemo{

          UserService userService;

          TestDemo(UserService userService){
              this.userService = userService;
          }

          public void registerUser(String name) {
              userService.setUserName(name);
              System.out.println("注册成功");
          }
      }
}

通过DEBUG的方式我们直观的看到并没有注入进来:

原因就是我们提到的手动通过单例模式获取示例对象

这里记不起来当初是为什么要通过这种方式去获取Bean,可能想调用静态的变量,但是中间又参杂着其他的逻辑不能通过类名的方式直接获取😭。

解决方案:

去掉通过单例模式获取实例的方法,因为Spring Bean本身就是单例的,无非就是通过Autowried进行注入下就行。

相关推荐
极地星光8 小时前
Qt/C++ 单例模式深度解析:饿汉式与懒汉式实战指南
c++·qt·单例模式
Mr.Winter`3 天前
基于Proto3和单例模式的系统参数配置模块设计(附C++案例实现)
c++·人工智能·单例模式·机器人
专注于大数据技术栈4 天前
java学习--单例模式之懒汉式
java·学习·单例模式
Murphy_lx5 天前
单例模式_
单例模式
wheeldown5 天前
【Linux】多线程核心速记:线程池 + 单例模式 + 线程安全 + 死锁 + 智能指针
linux·运维·服务器·安全·单例模式
Malone-AI7 天前
设计模式之单例模式
单例模式·设计模式
Irene19918 天前
JavaScript 模块 单例模式 和 副作用 详解
单例模式·副作用
那我掉的头发算什么8 天前
【javaEE】多线程 -- 超级详细的核心组件精讲(单例模式 / 阻塞队列 / 线程池 / 定时器)原理与实现
java·单例模式·java-ee
TechMasterPlus8 天前
java:单例模式
java·开发语言·单例模式
IT永勇10 天前
C++设计模式-单例
c++·单例模式·设计模式