volatile和synchronized区别&乐观锁、悲观锁

版权声明: https://blog.csdn.net/qq_16525279/article/details/82695956

volatile和synchronized区别

  • volatile是变量修饰符,其修饰的变量具有可见性,Java的做法是将该变量的操作放在寄存器或者CPU缓存上进行,之后才会同步到主存,使用volatile修饰符的变量是直接读写主存,volatile不保证原子性,同时volatile禁止指令重排。
  • synchronized作用于一段代码或者方法,保证可见性,又保证原子性,可见性是synchronized或者Lock能保证同一个时刻只有一个线程获取锁然后执行不同代码,并且在释放锁之前会对变量的修改刷新到主存中去,原子性是指要么不执行,要执行就执行到底。

Java中都有什么锁

重量级锁(synchronized)、显式锁(Lock接口)、并发容器、并发同步器、CAS、轻量级锁(volatile)、AQS等

可重入锁的设计思路是什么

  • 可重入公平锁获取流程,在获取锁的时候,如果当前线程之前已经获取到了锁,就会把state加1,在释放锁的时候会先减1,这样就保证了同一个锁可以被同一个线程获取多次,而不会出现死锁的情况。这就是ReentrantLock的可重入性。
  • 对于非公平锁而言,调用lock方法后,会先尝试抢占锁,在各种判断的时候会先忽略等待队列,如果锁可用,就会直接抢占使用。

乐观锁和悲观锁

乐观锁:假定不会发生并发冲突,只在数据提交时检查是否违反了数据完整性(不能解决脏读问题)

悲观锁:假定会发生并发冲突,则屏蔽一切可能违反数据完整性的操作

猜你喜欢

转载自blog.csdn.net/qq_16525279/article/details/82695956