1、volatile可以保证的是内存可见性和指令有序性,不能保证操作的原子性;synchronized可以保证的是内存的可见性和操作的原子性,不能保证同步块中的有序性(有人说synchronized可以保证有序性,其实synchronized保证的是指获取相同锁的同步块只能串行执行,但是同步块内的代码还是会发生重排序,还需要加入volatile才可以保证内部代码块的有序性(但是synchronized中的代码只能是单线程执行的,所以如果变量只出现在synchronized内的时候是不存在多线程下的重排序问题的))
2、volatile不需要加锁,比synchronized更轻量级
3、volatile是通过读写屏障保证内存可见性和指令的有序性的;而synchronized通过锁机制保证原子,通过加锁时把主存中的变量刷新到工作区中、解锁时刷新工作区内变量到主存中 实现内存可见性的(synchronized只有两个线程进入同一个锁的时候才能保持内存可见性:当ThreadA释放锁M时,它所写过的变量(比如,x和y,存在它工作内存中的)都会同步到主存中,而当ThreadB在申请同一个锁M时,ThreadB的工作内存会被设置为无效,然后ThreadB会重新从主存中加载它要访问的变量到它的工作内存中)。
参考:
Java中synchronized和volatile的区别
synchronized可以防止指令重排序吗