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")来指定不同的作用模式

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

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值