-
volatile不能保证原子性,只能保证可见性查看全部
-
sychronized<br> A当两个并发线程访问同一个对象object中的这个synchronized(this)同步代码块时,一个时间内只能有一个线程得到执行。 B当一个线程访问object的一个synchronized(this)同步代码块时,另一个线程仍然可以访问该object中的非synchronized(this)同步代码块。 C当一个线程访问object的一个synchronized(this)同步代码块时,其他线程对object中所有其它synchronized(this)同步代码块的访问会被阻塞。 D当一个线程访问object的一个synchronized(this)同步代码块时,它就获得了这个object的对象锁。结果,其它线程对该object对象所有同步代码部分的访问都被暂时阻塞。查看全部
-
可以加入休眠机制让一个线程执行完,另一个线程才执行,保证结果是6查看全部
-
即使没加sychronized关键字,共享变量也可以在工作内存和主内存中得到刷新查看全部
-
synchronized实现可见性的原理: 1. 2. 3.查看全部
-
解决上述线程安全性的代码如下查看全部
-
导致共享变量不可见的三个原因: 1.线程的交叉执行 2.重排序结合线程交叉执行 3.共享变量更新后的值没有在工作内存与主内存间及时更新查看全部
-
2.1 和 2.2 指令重排序后:查看全部
-
2.1 2.2 也可能会存在指令重排序,只有数据间的依赖关系才会禁止指令重排序查看全部
-
Java语言在单线程中遵循as-if-serial语义 重排序不会给单线程带来内存可见性问题 多线程中程序交错执行时,重排序可能会造成内存可见性问题查看全部
-
指令重排序:代码书写的顺序与实际执行的顺序不同,指令重排序是编译器或处理器为了提高程序性能而做的优化 1.编译器优化的重排序 2.指令级并行重排序 3.内存系统的重排序查看全部
-
线程执行互斥代码的过程: 1.获得互斥锁 2.查看全部
-
synchronized实现可见性的两条规定查看全部
-
synchronized可以实现内存可见性和原子性查看全部
-
Java语言中实现共享变量的可见性的两个关键字 volatile sychronized查看全部
举报
0/150
提交
取消