失效链接处理 |
2021年Java各知识点综合面试题 PDF 下载
本站整理下载:
相关截图:
主要内容:
1)现在有 T1、T2、T3 三个线程,你怎样保证 T2 在 T1 执行完后执行,T3 在 T2 执行完后执
行?
这个线程问题通常会在第一轮或电话面试阶段被问到,目的是检测你对”join”方法是否熟
悉。这个多线程问题比较简单,可以用 join 方法实现。
2)在 Java 中 Lock 接口比 synchronized 块的优势是什么?你需要实现一个高效的缓存,它允
许多个用户读,但只允许一个用户写,以此来保持它的完整性,你会怎样去实现它?
lock 接口在多线程和并发编程中最大的优势是它们为读和写分别提供了锁,它能满足你写
像 ConcurrentHashMap 这样的高性能数据结构和有条件的阻塞。Java 线程面试的问题越来
越会根据面试者的回答来提问。我强烈建议在你去参加多线程的面试之前认真读一下
Locks,因为当前其大量用于构建电子交易终统的客户端缓存和交易连接空间。
3)在 java 中 wait 和 sleep 方法的不同?
通常会在电话面试中经常被问到的 Java 线程面试问题。最大的不同是在等待时 wait 会释放
锁,而 sleep 一直持有锁。Wait 通常被用于线程间交互,sleep 通常被用于暂停执行。
4)用 Java 实现阻塞队列。
这是一个相对艰难的多线程面试问题,它能达到很多的目的。第一,它可以检测侯选者是
否能实际的用 Java 线程写程序;第二,可以检测侯选者对并发场景的理解,并且你可以根
据这个问很多问题。如果他用 wait()和 notify()方法来实现阻塞队列,你可以要求他用最新
的 Java 5 中的并发类来再写一次。
5)用 Java 写代码来解决生产者——消费者问题。
与上面的问题很类似,但这个问题更经典,有些时候面试都会问下面的问题。在 Java 中怎
么解决生产者——消费者问题,当然有很多解决方法,我已经分享了一种用阻塞队列实现
的方法。有些时候他们甚至会问怎么实现哲学家进餐问题。
6)用 Java 编程一个会导致死锁的程序,你将怎么解决?
这是我最喜欢的 Java 线程面试问题,因为即使死锁问题在写多线程并发程序时非常普遍,
但是很多侯选者并不能写 deadlock free code(无死锁代码?),他们很挣扎。只要告诉他
们,你有 N 个资源和 N 个线程,并且你需要所有的资源来完成一个操作。为了简单这里的
n 可以替换为 2,越大的数据会使问题看起来更复杂。通过避免 Java 中的死锁来得到关于
死锁的更多信息。
7) 什么是原子操作,Java 中的原子操作是什么?
|