java 锁

https://www.cnblogs.com/aspirant/p/6930436.html

ReentrantLock 就是自己lock 和 unlock 提供了更高级的特性:公平锁, 定时锁, 有条件锁, 可轮询锁, 可中断锁. 可以有效避免死锁的活跃性问题

读写锁解决了读与读之间的互斥。读写锁适用于读多写少的情况,可以实现更好的并发性。


除了synchronized之外,我们还可以使用java.util.concurrent(下文称J.U.C)包中的重入锁
(ReentrantLock)来实现同步,在基本用法上,ReentrantLock与synchronized很相似,他们都
具备一样的线程重入特性,只是代码写法上有点区别,一个表现为API层面的互斥锁
(lock()和unlock()方法配合try/finally语句块来完成),另一个表现为原生语法层面的互
斥锁。不过,相比synchronized,ReentrantLock增加了一些高级功能,主要有以下3项:等待可
中断、可实现公平锁,以及锁可以绑定多个条件。
等待可中断是指当持有锁的线程长期不释放锁的时候,正在等待的线程可以选择放弃等
待,改为处理其他事情,可中断特性对处理执行时间非常长的同步块很有帮助。
公平锁是指多个线程在等待同一个锁时,必须按照申请锁的时间顺序来依次获得锁;而
非公平锁则不保证这一点,在锁被释放时,任何一个等待锁的线程都有机会获得锁。
synchronized中的锁是非公平的,ReentrantLock默认情况下也是非公平的,但可以通过带布尔
值的构造函数要求使用公平锁。
锁绑定多个条件是指一个ReentrantLock对象可以同时绑定多个Condition对象,而在
synchronized中,锁对象的wait()和notify()或notifyAll()方法可以实现一个隐含的条
件,如果要和多于一个的条件关联的时候,就不得不额外地添加一个锁,而ReentrantLock则

无须这样做,只需要多次调用newCondition()方法即可。


https://www.cnblogs.com/qjjazry/p/6581568.html


乐观锁的一种实现方式-CAS(Compare and Swap 比较并交换):



  CAS 操作中包含三个操作数 —— 需要读写的内存位置(V)、进行比较的预期原值(A)和拟写入的新值(B)。如果内存位置V的值与预期原值A相匹配,那么处理器会自动将该位置值更新为新值B。否则处理器不做任何操作。无论哪种情况,它都会在 CAS 指令之前返回该位置的值。(在 CAS 的一些特殊情况下将仅返回 CAS 是否成功,而不提取当前值。)CAS 有效地说明了“ 我认为位置 V 应该包含值 A;如果包含该值,则将 B 放到这个位置;否则,不要更改该位置,只告诉我这个位置现在的值即可。 ”这其实和乐观锁的冲突检查+数据更新的原理是一样的。

    这里再强调一下,乐观锁是一种思想。CAS是这种思想的一种实现方式。


Java 语言中的 volatile 变量可以被看作是一种 “程度较轻的 synchronized

您只能在有限的一些情形下使用 volatile 变量替代锁。要使 volatile 变量提供理想的线程安全,必须同时满足下面两个条件:

  • 对变量的写操作不依赖于当前值。
  • 该变量没有包含在具有其他变量的不变式中。


理以上隔离级别的问题,采用如下方是:

  事务隔离五种级别:
        TRANSACTION_NONE  不使用事务。
        TRANSACTION_READ_UNCOMMITTED  允许脏读。
        TRANSACTION_READ_COMMITTED  防止脏读,最常用的隔离级别,并且是大多数数据库的默认隔离级别
        TRANSACTION_REPEATABLE_READ  可以防止脏读和不可重复读,
        TRANSACTION_SERIALIZABLE  可以防止脏读,不可重复读取和幻读,(事务串行化)会降低数据库的效率



猜你喜欢

转载自blog.csdn.net/seareal1/article/details/80250408
今日推荐