今天写牛客题目
简略了解一下volatile与synchronized的区别
基础概念
在并发编程中有两个关键性问题:线程之间如何通信以及线程之间如何同步
可见性
概括: 可见性是指线程之间的可见性,既一个线程修改之后,另外一个线程可以看到。指的是解决线程之间的通信问题
在Java中,用volatile、synchronized和final实现可见性。
原子性
概括: 既操作不可以再进行分割。
反例: a++,变量的自加操作实际是a=a+1,是可以分割的,所以自加并不是原子操作。非原子操作都会引起线程安全问题。java的concurrent包下有一些原子类,如AtomicInteger,AtomicLong
在Java中synchronized和lock、unlock操作保证原子性。
有序性
**概括:**大概相当于线程之间的运行顺序都是有一定按照程序员想的去运行的顺序。
Java提供了volatile和synchronized两个关键字保证线程之间操作的有序性
volatile
- 关键字volatile是线程同步的轻量级实现,所以运行性能较synchronized更好,但是volatile只能修饰变量。
- 多线程访问volatile不会阻塞
- volatile能保证数据的可见性,但是不能够保证原子性。
- volatile解决的是变量在多线程之间的可见性
synchronized
- synchronized性能消耗相对较大,并且可以修饰方法、代码块。
- 多线程访问synchronized会发生阻塞
- synchronized可以保证原子性,间接保证可见性。
- synchronized解决的是多线程之间资源同步问题