2018Java线程热门面试题,全部掌握之后轻松拿offer!

图片描述
1、什么是线程?

2、什么是线程安全和线程不安全?

3、什么是自旋锁?

4、什么是Java内存模型?

5、什么是CAS?

6、什么是乐观锁和悲观锁?

7、什么是AQS?

8、什么是原子操作?在Java Concurrency API中有哪些原子类(atomic classes)?

9、什么是Executors框架?

10、什么是阻塞队列?如何使用阻塞队列来实现生产者-消费者模型?

11、什么是Callable和Future?

12、什么是FutureTask?

13、什么是同步容器和并发容器的实现?

14、什么是多线程?优缺点?

15、什么是多线程的上下文切换?

16、ThreadLocal的设计理念与作用?

17、ThreadPool(线程池)用法与优势?

18、Concurrent包里的其他东西:ArrayBlockingQueue、CountDownLatch等等。

19、synchronized和ReentrantLock的区别?

20、Semaphore有什么作用?

21、Java Concurrency API中的Lock接口(Lock interface)是什么?对比同步它有什么优势?

22、Hashtable的size()方法中明明只有一条语句”return count”,为什么还要做同步?

23、ConcurrentHashMap的并发度是什么?

24、ReentrantReadWriteLock读写锁的使用?

25、CyclicBarrier和CountDownLatch的用法及区别?

26、LockSupport工具?

27、Condition接口及其实现原理?

28、Fork/Join框架的理解?

29、wait()和sleep()的区别?

30、线程的五个状态(五种状态,创建、就绪、运行、阻塞和死亡)?

31、start()方法和run()方法的区别?

32、Runnable接口和Callable接口的区别?

33、volatile关键字的作用?

34、Java中如何获取到线程dump文件?

35、线程和进程有什么区别?

36、线程实现的方式有几种(四种)?

37、高并发、任务执行时间短的业务怎样使用线程池?并发不高、任务执行时间长的业务怎样使用线程池?并发高、业务执行时间长的业务怎样使用线程池?

38、如果你提交任务时,线程池队列已满,这时会发生什么?

39、锁的等级:方法锁、对象锁、类锁?

40、如果同步块内的线程抛出异常会发生什么?

41、并发编程(concurrency)并行编程(parallellism)有什么区别?

42、如何保证多线程下 i++ 结果正确?

43、一个线程如果出现了运行时异常会怎么样?

44、如何在两个线程之间共享数据?

45、生产者消费者模型的作用是什么?

46、怎么唤醒一个阻塞的线程?

47、Java中用到的线程调度算法是什么

48、单例模式的线程安全性?

49、线程类的构造方法、静态块是被哪个线程调用的?

50、同步方法和同步块,哪个是更好的选择?

51、如何检测死锁?怎么预防死锁?

需要以上面试题答案的,关注我私聊回复Java线程面试获取。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值