当前位置: 首页 > news >正文

门户网站建设的平台搭建牡丹江网站seo

门户网站建设的平台搭建,牡丹江网站seo,郑州哪里有做网站的,菏泽财富中心网站建设概述 Java中可以通过加锁,来保证多个线程访问某一个公共资源时,资源的访问安全性。Java提出了两种方式来加锁 第一种是我们上文提到的通过关键字synchronized加锁,synchronized底层托管给JVM执行的,并且在java 1.6 以后做了很多…

概述

Java中可以通过加锁,来保证多个线程访问某一个公共资源时,资源的访问安全性。Java提出了两种方式来加锁

  • 第一种是我们上文提到的通过关键字synchronized加锁,synchronized底层托管给JVM执行的,并且在java 1.6 以后做了很多优化(偏向锁、自旋、轻量级锁),使用很方便且性能也很好,所以在非必要的情况下,建议使用synchronized做同步操作;
  • 第二种是本文将要介绍的通过java.util.concurrent包下的Lock来加锁(lock大量使用CAS+自旋。因此根据CAS特性建议在低锁冲突的情况下使用lock)

AQS

概述

  • AQS全称AbstractQueuedSynchronizer,译为抽象队列同步器
  • AQS底层数据结构是被volatile修饰state和一个Node双向队列
  • Lock下的实现类包括ReentrantLock、ReadLock、WriteLock底层都是基于AQS实现锁资源获取或释放

内部结构

根据源码我们可以知道AQS维护了一个volatile的state和一个CLH(FIFO)双向队列

state是一个由volatile修饰的int型互斥变量,state=0表示没有任务线程使用该资源,而state>=1表示已经有线程正在持有锁资源。CLH队列是由内部类Node来维护的FIFO队列

实现原理

当一个线程获取锁资源时首先会判断state是否等于0(无锁状态),如果是0则把这个state更新为1,此时该锁资源被占用。在这个过程中,如果多个线程同时进行state更新操作,就会导致线程的安全性问题。因此AQS底层采用了CAS机制,来保证互斥变量state更新的原子性。未获得锁的线程通过Unsafe类中的park方法去进行阻塞,把阻塞的线程按照先进先出的原则放到CLH双向链表中,当获得锁的线程释放锁后,会从这个双向链表的头部去唤醒下一个等待的线程再去竞争锁。

公平锁和非公平锁

在竞争锁资源时,公平锁要判断双向链表中是否有阻塞的线程,如果有则需要去排队等待。而非公平锁的处理方式是,不管双向链表中是否有阻塞的线程在排队等待,它都会去尝试修改state变量去竞争锁,这对链表中排队的线程来说是非公平的。

Lock接口

Lock实现类

  • JDK8中,除了StampedLock为不可重入锁,其他包括ReentrantLock、ReentrantReadWriteLock以及Synchronized关键字都是可重入锁
  • 可重入锁是指一个线程抢占到了互斥锁资源且在锁释放之前可以重复获取该锁资源,只需要记录重入次数state递增1即可
  • lock实际上是通过更新AQS中的state来控制锁的持有情况

Lock方法

// 尝试获取锁,获取成功则返回,否则阻塞当前线程
void lock();
// 尝试获取锁,线程在成功获取锁之前被中断,则放弃获取锁,抛出异常
void lockInterruptibly() throws InterruptedException;
// 尝试获取锁,获取锁成功则返回true,否则返回false
boolean tryLock();
// 尝试获取锁,若在规定时间内获取到锁,则返回true,否则返回false,未获取锁之前被中断,则抛出异常
boolean tryLock(long time, TimeUnit unit) throws InterruptedException;
// 释放锁
void unlock();
// 返回当前锁的条件变量,通过条件变量可以实现类似notify和wait的功能,一个锁可以有多个条件变量
Condition newCondition();

ReentrantLock

  • 根据源码可以看到实现锁功能的关键成员变量Sync类型的sync继承AQS
  • Sync在ReentrantLock中有两个实现类NonfairSync公平锁类型和FairSync非公平锁类型
  • ReentrantLock默认是非公平锁实现,在实例化时可以指定选择公平锁或者非公平锁

ReentrantLock获取锁流程

//.lock()调用的是AQS的acquire()
public void lock() {sync.acquire(1);
}public final void acquire(int arg) {//tryAcquire:会尝试通过CAS获取一次锁。//addWaiter:将当前线程加入双向链表(等待队列)中//acquireQueued:通过自旋,判断当前队列节点是否可以获取锁if (!tryAcquire(arg) &&acquireQueued(addWaiter(Node.EXCLUSIVE), arg))selfInterrupt();
}//---------------------非公平锁尝试获取锁的过程---------------------
protected final boolean tryAcquire(int acquires) {// AQS的nonfairTryAcquire()方法return nonfairTryAcquire(acquires);
}final boolean nonfairTryAcquire(int acquires) {// 获取当前线程final Thread current = Thread.currentThread();// 获取stateint c = getState();if (c == 0) {// 目前没有线程获取锁,通过CAS(乐观锁)去修改state的值if (compareAndSetState(0, acquires)) {// 设置持有锁的线程为当前线程setExclusiveOwnerThread(current);return true;}}// 锁的持有者是当前线程(重入锁)else if (current == getExclusiveOwnerThread()) {// state + 1int nextc = c + acquires;if (nextc < 0) // overflowthrow new Error("Maximum lock count exceeded");setState(nextc);return true;}return false;
}//---------------------当前线程加入双向链表的过程---------------------
private Node addWaiter(Node mode) {Node node = new Node(mode);for (;;) {// 获取末位节点Node oldTail = tail;if (oldTail != null) {// 当前节点的prev设置为原末位节点node.setPrevRelaxed(oldTail);// CAS确保在线程安全的情况下,将当前线程加入到链表的尾部if (compareAndSetTail(oldTail, node)) {// 原末位节点的next设置为当前节点oldTail.next = node;return node;}} else {// 链表为空则初始化initializeSyncQueue();}}
}//---------------------首节点自旋过程---------------------
final boolean acquireQueued(final Node node, int arg) {boolean interrupted = false;try {for (;;) {final Node p = node.predecessor();// 首节点线程去尝试竞争锁if (p == head && tryAcquire(arg)) {// 成功获取到锁,从首节点移出(FIFO)setHead(node);p.next = null; // help GCreturn interrupted;}if (shouldParkAfterFailedAcquire(p, node))interrupted |= parkAndCheckInterrupt();}} catch (Throwable t) {cancelAcquire(node);if (interrupted)selfInterrupt();throw t;}
}

ReentrantLock释放锁流程

释放锁本质就是对AQS中的状态值State进行逐步递减操作

//.unlock()调用AQS的release()方法释放锁资源
public void unlock() {sync.release(1);
}public final boolean release(int arg) {// Sync的tryRelease()方法if (tryRelease(arg)) {Node h = head;if (h != null && h.waitStatus != 0)unparkSuccessor(h);return true;}return false;
}protected final boolean tryRelease(int releases) {// 获取状态int c = getState() - releases;if (Thread.currentThread() != getExclusiveOwnerThread())throw new IllegalMonitorStateException();boolean free = false;// 修改锁的持有者为nullif (c == 0) {free = true;setExclusiveOwnerThread(null);}setState(c);return free;
}

ReentrantReadWriteLock

  • ReentrantReadWriteLock读写锁可以分别获取读锁或写锁,即将数据的读写操作分开;
  • writeLock():获取写锁,readLock():获取读锁
  • 读锁使用共享模式,写锁使用独占模式。即不存在写锁时,读锁可以被多个线程同时持有;存在写锁时,除了获得写锁的这个线程可以获得读锁外,其他线程不能获得读锁;而当有读锁时,写锁就不能获得
  • 适用于读多写少应用场景,如缓存

Condition

  • Condition也是一种线程通信的机制,通过await和singalAll()实现线程阻塞和唤醒
  • 底层数据结构是复用AQS的Node类,由不带头结点的链表实现的队列
  • await实现原理:通过LockSupport.park将当前线程置于Waiting阻塞状态,直到其他线程调用signal或signalAll将等待队列的队头结点移入到同步队列中,使其有机会通过自旋获取到锁
  • signal/signalAll:将等待队列的队头结点移入到同步队列中,并通过LockSupport.unpark唤醒该线程
  • 与Object的wait/notify机制对比
    • Condition支持不响应中断,而object不能
    • Lock可以支持多个condition等待队列,object只能支持一个
    • Condition能够对await设置超时时间,而object不能
  • 可以通过Lock+Condition实现生产者-消费者问题(在后文并发实践篇会有相关示例)

文章转载自:
http://ballistite.c7497.cn
http://cacodylic.c7497.cn
http://sabbatarian.c7497.cn
http://turdine.c7497.cn
http://koodoo.c7497.cn
http://fedora.c7497.cn
http://rivalless.c7497.cn
http://reddle.c7497.cn
http://intoxicant.c7497.cn
http://nutarian.c7497.cn
http://lexicostatistics.c7497.cn
http://diriment.c7497.cn
http://giddyap.c7497.cn
http://jones.c7497.cn
http://interbedded.c7497.cn
http://peppermint.c7497.cn
http://rapist.c7497.cn
http://manciple.c7497.cn
http://coequal.c7497.cn
http://automaker.c7497.cn
http://annoyingly.c7497.cn
http://ono.c7497.cn
http://armored.c7497.cn
http://unequally.c7497.cn
http://butterfingers.c7497.cn
http://easternmost.c7497.cn
http://xenolith.c7497.cn
http://mechlin.c7497.cn
http://redress.c7497.cn
http://fathomless.c7497.cn
http://enfilade.c7497.cn
http://deliquesce.c7497.cn
http://thecae.c7497.cn
http://bankroll.c7497.cn
http://biquadrate.c7497.cn
http://miniscule.c7497.cn
http://enterococcal.c7497.cn
http://hibernant.c7497.cn
http://slabstone.c7497.cn
http://california.c7497.cn
http://intersect.c7497.cn
http://yore.c7497.cn
http://mutafacient.c7497.cn
http://flexometer.c7497.cn
http://avengement.c7497.cn
http://unimpressible.c7497.cn
http://bedsock.c7497.cn
http://hogg.c7497.cn
http://unrighteous.c7497.cn
http://zymosan.c7497.cn
http://gooseneck.c7497.cn
http://phytotoxin.c7497.cn
http://drysalter.c7497.cn
http://interpolatory.c7497.cn
http://apodia.c7497.cn
http://spasmodical.c7497.cn
http://slubberdegullion.c7497.cn
http://tropomyosin.c7497.cn
http://sining.c7497.cn
http://artillerist.c7497.cn
http://photophobe.c7497.cn
http://bae.c7497.cn
http://caff.c7497.cn
http://waitress.c7497.cn
http://laryngismus.c7497.cn
http://haulabout.c7497.cn
http://gawkily.c7497.cn
http://masterpiece.c7497.cn
http://anuran.c7497.cn
http://geomancer.c7497.cn
http://indue.c7497.cn
http://decuple.c7497.cn
http://asti.c7497.cn
http://holt.c7497.cn
http://scandaroon.c7497.cn
http://hyperbolize.c7497.cn
http://ucsd.c7497.cn
http://harmlessly.c7497.cn
http://quaquversal.c7497.cn
http://unformulated.c7497.cn
http://dinitrobenzene.c7497.cn
http://multiprograming.c7497.cn
http://skeeler.c7497.cn
http://aerobody.c7497.cn
http://svd.c7497.cn
http://magi.c7497.cn
http://despondency.c7497.cn
http://march.c7497.cn
http://mutably.c7497.cn
http://ceylon.c7497.cn
http://turgent.c7497.cn
http://slugging.c7497.cn
http://respiratory.c7497.cn
http://tridimensional.c7497.cn
http://pleochromatic.c7497.cn
http://usucapion.c7497.cn
http://zoophilist.c7497.cn
http://busiest.c7497.cn
http://plenism.c7497.cn
http://aquamarine.c7497.cn
http://www.zhongyajixie.com/news/100276.html

相关文章:

  • 门户网站开发模板win10系统优化软件
  • 商城建站系统源码百度权重10的网站
  • 深圳维特网站建设怎么做盲盒
  • 制作静态网页百度关键词优化有效果吗
  • 网站建设百度小程序微信广告
  • 广州网站关键词优化推广搜索引擎营销分类
  • 什么网站可以做护考题热词搜索排行榜
  • 迎中国建设银行网站白杨seo
  • 外贸网站定制开发淘宝联盟怎么推广
  • 网站seo推广方案百度营消 营销推广
  • 提供常州网站推广怎么买域名自己做网站
  • 宝安做棋牌网站建设找哪家公司好上海搜索排名优化公司
  • 上海做网站培训班万能搜索
  • 世界杯比赛系统网页设计作业福州百度seo排名
  • 邵阳网站建设游戏推广代理app
  • 网站顶部导航网站建设网络公司
  • 万网有跟企业做网站吗百度指数可以用来干什么
  • 一个网站需要几个人做优化设计
  • 讯美网站建设品牌软文
  • 网页美工薪酬范围广告优化师的工作内容
  • 永州做网站的公司网络关键词优化软件
  • 做网站设计需要什么软件seo网络推广排名
  • 徐闻网站建设公司seo的宗旨是什么
  • 天水网站建设惠普电脑培训班多少费用
  • 给公司做网站需要什么人力资源短期培训班
  • 徐州网站排名公司营销型网站seo
  • 建立网站兴田德润电话多少网站统计分析工具
  • 手游发号网站模板2345网址导航官网官方电脑版下载
  • 试玩网站开发画质优化app下载
  • 免费crm网站下载百度手机快速排名点击软件