可见性概念:一个线程对共享变量值的修改,能够及时地被其他线程看到。
共享变量:如果一个变量在多个线程的工作内存中都存在副本,那么这个变量就是这几个线程的共享变量。
JAVA内存模型(JMM):
所有的变量都存储在主内存中
每个线程都有自己的独立的工作内存,里面保存了该线程使用到的变量的副本(主内存中该变量的一份拷贝)
1、共享变量在线程间的可见性
1.1、synchronized实现可见性
线程释放锁时,会自动地把工作内存中副本刷新到主内存,然后其他线程获得锁时能及时的向内存中获取最新的变量值,从而实现可见性。
1.2、volatile实现可见性
线程中修改了变量的值,会及时地把工作内存中副本刷新到主内存,然后其他线程能及时的向内存中获取最新的变量值,从而实现可见性。
指令重排序
指令重排序不会影响到单线程执行输出的结果,但是会对多线程造成影响。
volatile能禁止其前后代码语句进行重排序
as-if-serial语义
volatile使用注意事项
3、synchronized和volatile比较
常用synchronized,而volatile主要用于boolean标志位或者共享变量不依赖于当前值的情况下
volatile 中 boolean共享变量可以设置线程终止条件(while循环时),让线程能执行完剩余操作而安全退出;
而Thread.stop()是线程非安全退出,执行结果无法预料(到底执行到那就结束了),所以stop()方法已弃用;同时Thread.interrupt()也是错误的停止线程方法,达不到线程停止的理想状态