concurrent之CAS

你的对手在看书,你的仇人在磨刀,你的闺蜜在减肥,隔壁老王在练腰

  CAS是什么?

  比较并交换,compareAndSet,类似于版本冲突,如果主物理内存和线程中的数据是否相等,则进行交互

  实际应用的类型,AtomicInteger(原子整型),AtomicReference(自定义原子类型) 

CAS底层原理:
  比较当前工作内存中的值和主内存中的值,如果相同则执行规定操作,否则继续比较直到主内存和工作内存中的值一致为止  

  unsafe:是CAS的核心类,只能通过本地方法访问,可以直接操作特定内存数据,底层compareAndSwapInt
  变量valueOffset,表示变量值在内存中偏移地址,Unsafe就是根据内存偏移地址获取数据
  
  是一条CPU的原子指令,直接操作内存,不会造成数据不一致问题

缺点:
  极端情况,如果CAS长时间一直不成功,会给CPU带来很大的开销,使用的是do while
  只能保证一个变量的原子操作
  引出ABA问题,在当前时刻比较,这个时间差会导致数据的变化

解决ABA问题:
  添加时间戳

ReentrantLock锁线程:

  默认非公平锁,是指多个线程获取锁的顺序并不是按照申请锁的顺序,有可能后申请的线程比先申请的线程优先获取锁在并发的情况下,有可能会造成优先级反转

  公平锁是按照申请锁的顺序来获取锁,类似排队打饭

  可重入锁

 

Synchronized锁对象和类

  也是非公平锁

  可重入锁

 

可重入锁(递归锁):

  是指同一线程外层函数获取锁之后,内层递归函数仍然能获取该锁,在内层方法自动获取锁

自旋锁

  尝试获取锁的线程,不会立即阻塞,而是采用循环的方式去尝试获取锁,避免线程的上下文切换,缺点会消耗cpu

  while (!atomicReference.compareAndSet(null, thread)) 

独占锁(可写), 共享锁(可读),互斥锁(读写锁)

ReentrantReadWriteLock rwLock = new ReentrantReadWriteLock();
       rwLock.writeLock();
       rwLock.readLock();

CountDownlatch

  await:进行阻塞

CyclicBarrier

   

atomicInteger.compareAndSet(1, 100);

 atomicInteger.get();

  

  

posted @ 2021-10-12 19:32  外科手术医生  阅读(62)  评论(0编辑  收藏  举报