Spring Controller全局变量引起的问题

时间:2024-06-01 10:13:50

一直以来都是方法之间进行参数的传递,对参数进行各种修改然后返回这样没有任何的问题,直到昨天遇到了我的同事写的代码,项目使用的是springcloud全家桶,他在代码中编写如下;

接口看起来没什么问题,入参正常,返回一个集合,声明了一个全局变量List集合matchInvoiceList用来进行接收某些方法之间的数据,并且进行对数据的操作,但是这样有两个非常要命的问题;
Spring Controller全局变量引起的问题

问题:
1.spring是单例模式,并发的场景下,全局变量会有线程安全的问题;
2.会出现第二次访问这个接口的时候,集合并没有重新实例化,其中的数据还是上次请求得到的结果;

现这种问题如何解决呢?

第一种方式: 既然是全局变量惹的祸,那就将全局变量都编程局部变量,通过方法参数来传递。

第二种方式:jdk提供了java.lang.ThreadLocal,它为多线程并发提供了新思路。 (当使用ThreadLocal维护变量时,ThreadLocal为每个使用该变量的线程提供独立的变量副本,所以每一个线程都可以独立地改变自己的副本,而不会影响其它线程所对应的副本)

第三种:使用@Scope(“session”)或者,会话级别

第四种:将控制器的作用域从单例改为原型,即在spring配置文件Controller中声明@Scope(“prototype”),每次都创建新的controller

代码示例如下
Spring Controller全局变量引起的问题

Spring Controller全局变量引起的问题
使用ThreadLocal的时候需要注意,set进去你指定的参数,然后get拿出来,最后操作完了之后需要调用remove方法,如果不调用会造成内存泄漏和影响后续的业务逻辑;

参考文章
https://blog.****.net/a491057947/article/details/49933391
https://www.cnblogs.com/jiazhutao/p/12675577.html
https://blog.****.net/weixin_33387378/article/details/87933743?utm_medium=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.compare&depth_1-utm_source=distribute.pc_relevant.none-task-blog-BlogCommendFromMachineLearnPai2-1.compare