全国旗舰校区

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

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  应聘面试  >  Java面试题

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程序员梦想。

相关文章

华为外包java面试题-Java实现单链表的逆序

2023-07-25

Java程序员面试题

2023-07-21

Java面试题及答案

2023-07-20

什么是Java中的线程?如何创建和启动线程?

2023-07-18

Java中的异常处理机制是什么?请解释try-catch-finally块的作用

2023-07-18

面向对象编程的特征是什么?请解释每个特征

2023-07-18
在线咨询 免费试学 教程领取