zoukankan      html  css  js  c++  java
  • spring的controller默认是单例还是多例

    先看看spring的bean作用域有几种,分别有啥不同。

    spring bean作用域有以下5个:

    singleton:单例模式,当spring创建applicationContext容器的时候,spring会欲初始化所有的该作用域实例,加上lazy-init就可以避免预处理;

    prototype:原型模式,每次通过getBean获取该bean就会新产生一个实例,创建后spring将不再对其管理;

    ====下面是在web项目下才用到的===

    request:搞web的大家都应该明白request的域了吧,就是每次请求都新产生一个实例,和prototype不同就是创建后,接下来的管理,spring依然在监听

    session:每次会话,同上

    global session:全局的web域,类似于servlet中的application

    好了,上面都说了spring的controller默认是单例,那很自然就是singleton了。

    再看一个例子,看看单例会不会有我说的那种问题(就是类中定义的非静态变量线程安全问题),当然下面这个例子我是实验过的, 要不然也不敢发出来

    为什么spring要默认是单例呢?原因有二:

    1、为了性能。

    2、不需要多例。

    1、这个不用废话了,单例不用每次都new,当然快了。

    2、不需要实例会让很多人迷惑,因为spring mvc官方也没明确说不可以多例。

      我这里说不需要的原因是看开发者怎么用了,如果你给controller中定义很多的属性,那么单例肯定会出现竞争访问了。

      因此,只要controller中不定义属性,那么单例完全是安全的。下面给个例子说明下:

     
    package com.lavasoft.demo.web.controller.lsh.ch5;
    import org.springframework.context.annotation.Scope;
    import org.springframework.stereotype.Controller;
    import org.springframework.ui.ModelMap;
    import org.springframework.web.bind.annotation.RequestMapping;
    /**
     * Created by Administrator on 14-4-9.
     *
     * @author leizhimin 14-4-9 上午10:55
     */
    @Controller
    @RequestMapping("/demo/lsh/ch5")
    public class MultViewController {
        
        privateintindex = 0;         //非静态
        @RequestMapping("/show")
        publicStringtoShow(ModelMap model) {
            System.out.println(++i);
            return"/lsh/ch5/show";
        }
        @RequestMapping("/test")
        publicStringtest() {
            System.out.println(++i);
            return"/lsh/ch5/test";
        }
    }

    改为多例的(就是在class上面加一个@Scope("request")):

    1 | 1

    从此可见,单例是不安全的,会导致属性重复使用。

    最佳实践:

    1、不要在controller中定义成员变量。

    2、万一必须要定义一个非静态成员变量时候,则通过注解@Scope("prototype"),将其设置为多例模式。

  • 相关阅读:
    oracle如何在所有procedure里搜索某些关键字, 存储过程
    Delphi 中文件的操作FileOpen
    【oracle】varchar和varchar2区别
    Delphi 2010 新增功能之: IOUtils 单元(6): TPath(结构体) 的方法与属性
    oracle如何在所有procedure里搜索某些关键字, 存储过程
    Delphi ADOConnection连接 sqlserver
    一种在SQLServer中实现Sequence的高效方法
    SQL Server 序列(SEQUENCE)使用
    [惠普HP] HP1215出现硒鼓底灰刮板拆机图解教程
    记录一下 山客 BK650 UPS 的配置软件下载地址
  • 原文地址:https://www.cnblogs.com/aspirant/p/11450862.html
Copyright © 2011-2022 走看看