全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  技术干货

java面试题:java知识点合集(十)

发布时间:2022-07-14 16:45:52
发布人:wjy

  一. AQS资源共享方式

  AQS有两种资源共享方式:Exclusive(独占)和Share(共享)。

  1. Exclusive(独占)

  只有一个线程能执行,如ReentrantLock,可分为公平锁和非公平锁:

  公平锁:按照线程在队列中的排队顺序,先到者先拿到锁

  非公平锁:当线程要获取锁时,无视队列顺序直接去抢锁,谁抢到就是谁的

  2. Share(共享)

  多个线程可同时执行,如Semaphore/CountDownLatch。Semaphore、CountDownLatch、 CyclicBarrier、ReadWriteLock 我们都会在后面讲到。

  ReentrantReadWriteLock 可以看成是组合式,因为ReentrantReadWriteLock也就是读写锁允许多个线程同时对某一资源进行读。

  不同的自定义同步器争用共享资源的方式也不同。自定义同步器在实现时只需要实现共享资源 state 的获取与释放方式即可,至于具体线程等待队列的维护(如获取资源失败入队/唤醒出队等),AQS已经在顶层实现好了。

java面试题:java知识点合集

  二. 如何让 Java 的线程彼此同步?

  主要是利用如下技术:

  synchronized

  volatile

  ReenreantLock

  使用局部变量实现线程同步

  三. 你了解过哪些同步器?请分别介绍下

  1. Semaphore同步器

  特征:

  经典的信号量,通过计数器控制对共享资源的访问

  Semaphore(int count):创建拥有count个许可证的信号量

  acquire()/acquire(int num) : 获取1/num个许可证

  release/release(int num) : 释放1/num个许可证

  2. CountDownLatch同步器

  特征:

  必须发生指定数量的事件后才可以继续运行(比如赛跑比赛,裁判喊出3,2,1之后大家才同时跑)

  CountDownLatch(int count):必须发生count个数量才可以打开锁存器

  await:等待锁存器

  countDown:触发事件

  3. CyclicBarrier同步器

  特征:

  适用于只有多个线程都到达预定点时才可以继续执行(比如斗地主,需要等齐三个人才开始)

  CyclicBarrier(int num) :等待线程的数量

  CyclicBarrier(int num, Runnable action) :等待线程的数量以及所有线程到达后的操作

  await() : 到达临界点后暂停线程

  4. 交换器(Exchanger)同步器

  5. Phaser同步器

  更多关于“Java培训”的问题,欢迎咨询千锋教育在线名师。千锋已有十余年的培训经验,课程大纲更科学更专业,有针对零基础的就业班,有针对想提升技术的好程序员班,高品质课程助力你实现java程序员梦想。

相关文章

抖音小店怎么进入精选联盟入口呢

2023-09-30

抖音小店怎么更改主体信息

2023-09-30

开抖音小店无货源需要多久

2023-09-30

开抖音小店需要多少费用汽车配件

2023-09-30

抖音小店在哪回复评价

2023-09-30

抖音小店怎么做标题呢图片大全

2023-09-30
在线咨询 免费试学 教程领取