SpringMVC 在controller层中注入成员变量request,是否线程安全

栏目: Java · 发布时间: 6年前

内容简介:上述代码是觉见的代码,为了使用方便,使用Autowire注入成员变量request后,直接在controller的方法中使用request。由于controller默认是单例的,那么是否会有线程安全问题呢?在框架初始IOC的时候是创建了一个Request对象的代理类,从而完成了初始注入,代理类负责从ThreadLocal中获取真正的Request对象并调用相应的方法,每次调用代理request的方法都相当于调用了该次请求真正的request对象的方法,因此不产生线程安全的问题。

阅读更多

@RestController
public class MyController{
 
    @Autowire
    HttpServletRequest request;
    
    @RequestMapping("/test")
    public String test(){
        String param = request.getParameter("param");
        //request.getHeader("uid");
        return param;
    }
}

上述代码是觉见的代码,为了使用方便,使用Autowire注入成员变量request后,直接在controller的方法中使用request。由于controller默认是单例的,那么是否会有线程安全问题呢?

在框架初始IOC的时候是创建了一个Request对象的代理类,从而完成了初始注入,代理类负责从ThreadLocal中获取真正的Request对象并调用相应的方法,每次调用代理request的方法都相当于调用了该次请求真正的request对象的方法,因此不产生线程安全的问题。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

长尾理论

长尾理论

[美] 克里斯·安德森 / 乔江涛 / 中信出版社 / 2006-12 / 35.00元

书中阐述,商业和文化的未来不在于传统需求曲线上那个代表“畅销商品”(hits)的头部; 而是那条代表“冷门商品”(misses)经常为人遗忘的长尾。 举例来说, 一家大型书店通常可摆放10万本书,但亚马逊网络书店的图书销售额中,有四分之一来自排名10万以后的书籍。这些“冷门”书籍的销售比例正以高速成长,预估未来可占整体书市的一半。 这意味着消费者在面对无限的选择时,真正想要的东西、和想要取得......一起来看看 《长尾理论》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试