springIOC容器管理的bean默认都是单例的

 

springIOC容器管理的bean默认都是单例的

我们平时使用的 @controller注解标注的控制器、@Service标注的接口等  默认都是单例的

那么也就是说,我们定义一个成员变量,线程之间可以共用!

滑稽!!!干了几年了我竟然不知道。先模拟个锁玩一下
 

/**
 * 测试spring 管理的bean 的作用域 锁模拟
 */
@RestController
@RequestMapping("/lock/")
public class SpringActionScopelockController {

    private boolean lock = false;

    @RequestMapping("open1")
    public String open1() {
        while (lock) {
        }
        System.out.println("open1抢到锁了");
        lock = true;
        try {
            Thread.sleep(5000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        lock =false;
        System.out.println("open1释放锁了");
        return "ok";
    }

    @RequestMapping("open2")
    public String open2() {
        while (lock) {
        }
        System.out.println("open2抢到锁了");
        lock = true;
        try {
            Thread.sleep(5000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        lock =false;
        System.out.println("open2释放锁了");
        return "ok";
    }
}

同时访问 open1和open2

控制台打印如下

open2抢到锁了
open2释放锁了
open1抢到锁了
open1释放锁了

一个模拟的本地同步锁就诞生了,虽然还是不很严谨,可能会出现并发安全问题。

下面介绍下 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

使用方法 增加注解 @Scope("prototype")来指定不同的作用模式

结尾~~~~~抱着死磕到底的态度,下期准备优化锁,自己实现一个线程安全的锁!初步看了一下,还挺难的,暂无好的思路。如果大家有这方面的思路,欢迎留言教导!!!感谢大家

你可能感兴趣的:(spring,boot)