博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
高级装配—bean的作用域
阅读量:5290 次
发布时间:2019-06-14

本文共 1351 字,大约阅读时间需要 4 分钟。

高级装配—bean的作用域

Spring定义了多种作用域,可以基于这些作用域创建bean,包括:

  • 单例(Singleton):在整个应用中,只创建bean的一个实例.
  • 原型(Prototype):每次注入或者通过Spring应用上下文获取的时候,都会创建一个新的bean实例.
  • 会话(Session):在web应用中,为每个会话创建一个bean实例.
  • 请求(Request):在web应用中,为每个请求创建一个bean实例.

单例是默认的作用域,但是正如之前所描述,对于易变的类型,这并不合适.如果选择其他作用域,要使用@Scope注解,他可以和@Component或@Bean一起使用.

@Component@Scope(ConfigurableBeanFactory.SCOPE_PROTOTYPE)public class NotPad {}
@Component@Scope("prototype")public class NotPad {}

当然你也可以用XML来配置bean:

使用会话和请求作用域

​ 在web的应用中经常会用到会话和请求的作用域,这里就拿购物车这个例子来说吧,每个客户都会向购物车添加商品,这时我们希望当前用户能一直使用对应的bean,这时就需要涉及到会话作用域了,如下进行配置:

Component @Scope( value = WebApplicationContext.SCOPE_SESSION, proxyMode = ScopedProxyMode.INTERFACES ) public ShoppingCart Cart { }

WebApplicationContext.SCOPE_SESSION 这里是指的Spring会为Web应用中的每个会话创建一个ShoppingCart.这里创建多个ShoppingCart的bean的实例,但是对于给定的会话只会创建一个实例,在在当前会话相关的操作中,这个bean实际上相当于单例的.

proxyMode会让每次会话注入到ShoppingCart的bean的代理,从而让所使用的ShoppingCart的实例恰好是当前会话所对应的那一个.

ScopedProxyMode.INTERFACES说明这个代理要实现ShoppingCart接口,从而将调用委托个实现bean.

当然bean原本是具体的类,我们可以设置为proxyMode = ScopedProxyMode.TARGET_CLASS,以此来表明要以生成目标类拓展的方式创建代理.

注意:尽管我们主要关注了会话作用域,但是请求作用域的bean会面临相同的问题,因此,请求作用域的bean应该也以作用域代理的方式进行注入.

在XML中声明作用域的代理

我们也可以通过XML的方式来声明作用域,如下:

当然,我们还可以通过roxy-target-class="false"声明基于接口的代理:

 

转载于:https://www.cnblogs.com/socketqiang/p/11325131.html

你可能感兴趣的文章
IO-properties
查看>>
object类
查看>>
java集合
查看>>
java String类
查看>>
java Stringbuffer类
查看>>
正则表达式(java)
查看>>
正则表达式(java)规则大全
查看>>
java date类
查看>>
DateFormat类,Calendar类(日历类)
查看>>
stm32 usb调试
查看>>
Debug printf viewer
查看>>
stm32 TIM
查看>>
stm32HAL重要的库
查看>>
深浅cope
查看>>
bat 批量重命名文件 并替换部分字符
查看>>
Centos使用chrony做时间同步
查看>>
tcpreplay命令使用详解
查看>>
转-四层和七层负载均衡的区别
查看>>
docker私有库搭建过程(Registry)
查看>>
kubernetes重置(重装)node的flannel网络
查看>>