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")来指定不同的作用模式
结尾~~~~~抱着死磕到底的态度,下期准备优化锁,自己实现一个线程安全的锁!初步看了一下,还挺难的,暂无好的思路。如果大家有这方面的思路,欢迎留言教导!!!感谢大家