Java再学习——synchronized与volatile
2015-11-14 23:49
260 查看
volatile:只保证共享资源的可见性的,任何修改都写在主存,所有线程马上就能看到,适用于新值不依赖于旧值的情形。
synchronized:保证可操作的原子性一致性和可见性。
volatile和synchronized的区别:
volatile仅仅使变量在值发生改变时能尽快地让其他线程知道,并不能保证多线程的执行有序性。而synchronized则是锁定当前变量,只有当前线程可以访问该变量,其他线程被阻塞住。
volatile仅能实现变量的修改可见性但不具备原子特性,而synchronized则可以保证变量的修改可见性和原子性.
volatile不会造成线程的阻塞,而synchronized可能会造成线程的阻塞.
volatile标记的变量不会被编译器优化,而synchronized标记的变量可以被编译器优化.
附录:
1、当一个线程进入某个对象的一个实例的synchronized方法后,其它线程就不可以访问该方法了,但是可以同时访问这个对象的非同步方法
2、Lock 和 synchronized 的区别 —— lock必须要在使用后释放,一般在 finally 块中释放。否则,如果受保护的代码将抛出异常,锁就有可能永远得不到释放。
synchronized:保证可操作的原子性一致性和可见性。
volatile和synchronized的区别:
volatile仅仅使变量在值发生改变时能尽快地让其他线程知道,并不能保证多线程的执行有序性。而synchronized则是锁定当前变量,只有当前线程可以访问该变量,其他线程被阻塞住。
volatile仅能实现变量的修改可见性但不具备原子特性,而synchronized则可以保证变量的修改可见性和原子性.
volatile不会造成线程的阻塞,而synchronized可能会造成线程的阻塞.
volatile标记的变量不会被编译器优化,而synchronized标记的变量可以被编译器优化.
附录:
1、当一个线程进入某个对象的一个实例的synchronized方法后,其它线程就不可以访问该方法了,但是可以同时访问这个对象的非同步方法
2、Lock 和 synchronized 的区别 —— lock必须要在使用后释放,一般在 finally 块中释放。否则,如果受保护的代码将抛出异常,锁就有可能永远得不到释放。
相关文章推荐
- javax.net.ssl.SSLException: hostname in certificate didn't match:
- 学习Spring .net(2)--开发环境配置
- 线程池
- JAVA设计模式(23) —<行为型>解释器模式(Interpreter)
- 搭建maven+spring+freemaker+mybatis环境之三
- javac / java
- 在Spring3 MVC中五步配置集成注解方式Hibernate3
- Java再学习——栈(stack)和堆(heap)
- 怎么学习一门新的技术
- Java基础02 方法与数据成员
- Java再学习——深究static关键字
- Spring MVC笔记
- java学习碰到死胡同了
- 在xml中调用自己用java代码定义的View
- java设计模式—工厂模式
- springmvc3.2+mybatis2.3.7整合
- java 内存区域
- java 内存机制
- Java笔记---别名现象
- JAVA内部类