前言

现在不管是大公司还是小公司,去面试都会问到多线程与并发编程的知识,大家面试的时候这方面的知识一定要提前做好储备。

1.多线程有什么用?

发挥多核CPU 的优势

随着工业的进步,现在的笔记本、台式机乃至商用的应用服务器至少也都是双核的,4 核、8 核甚至 16 核的也都不少见,如果是单线程的程序,那么在双核 CPU 上 就浪费了 50%, 在 4 核 CPU 上就浪费了 75%。

单核 CPU 上所谓的"多线程"那是假的多线程,同一时间处理器只会处理一段逻辑,只不过线程之间切换得比较快, 看着像多个线程"同时"运行罢了。

多核 CPU 上的多线程才是真正的多线程,它能让你的多段逻辑同时工作,多线程,可以真正发挥出多核CPU 的优势来,达到充分利用CPU 的目的。

防止阻塞

从程序运行效率的角度来看,单核 CPU 不但不会发挥出多线程的优势,反而会因为在单核CPU 上运行多线程导致线程上下文的切换,而降低程序整体的效率。但

是单核 CPU 我们还是要应用多线程,就是为了防止阻塞。试想,如果单核 CPU 使用单线程,那么只要这个线程阻塞了,比方说远程读取某个数据吧,对端迟迟未返回又没有设置超时时间,那么你的整个程序在数据返回回来之前就停止运行了。

多线程可以防止这个问题,多条线程同时运行,哪怕一条线程的代码执行读取数据阻塞,也不会影响其它任务的执行。

便于建模

这是另外一个没有这么明显的优点了。假设有一个大的任务 A,单线程编程,那么就要考虑很多,建立整个程序模型比较麻烦。但是如果把这个大的任务 A 分解成几个小任务,任务B、任务 C、任务 D,分别建立程序模型,并通过多线程分别运行这几个任务,那就简单很多了。

2.线程和进程的区别是什么?

进程和线程的主要差别在于它们是不同的操作系统资源管理方式。进程有独立的地址空间,一个进程崩溃后,在保护模式下不会对其它进程产生影响,而线程只是一个进程中的不同执行路径。

线程有自己的堆栈和局部变量,但线程之间没有单独的地址空间,一个线程死掉就等于整个进程死掉,所以多进程的程序要比多线程的程序健壮,但在进程切换时,耗费资源较大,效率要差一些。但对于一些要求同时进行并且又要共享某些变量的并发操作,只能用线程,不能用进程。

3.Java 实现线程有哪几种方式?

  • 继承 Thread 类实现多线程
  • 实现 Runnable 接口方式实现多线程
  • 使用 ExecutorService、Callable、Future 实现有返回结果的多线程

4.启动线程方法 start()和 run()有什么区别?

只有调用了 start()方法,才会表现出多线程的特性,不同线程的 run()方法里面的代码交替执行。如果只是调用 run()方法,那么代码还是同步执行的,必须等待一个线程的 run()方法里面的代码全部执行完毕之后,另外一个线程才可以执行其 run()方法里面的代码。

5.怎么终止一个线程?如何优雅地终止线程?

stop 终止,不推荐。

6.一个线程的生命周期有哪几种状态?它们之间如何流转的?

7.线程中的 wait()和 sleep()方法有什么区别?

8.多线程同步有哪几种方法?

9.什么是死锁?如何避免死锁?

10.多线程之间如何进行通信?

11、线程怎样拿到返回结果?

12、violatile 关键字的作用?

13、新建 T1、T2、T3 三个线程,如何保证它们按顺序执行?

14、怎么控制同一时间只有 3 个线程运行?

15、为什么要使用线程池?

16、常用的几种线程池并讲讲其中的工作原理。

17、线程池启动线程 submit()和 execute()方法有什么不同?

18、CyclicBarrier 和 CountDownLatch 的区别?

19、什么是活锁、饥饿、无锁、死锁?

20、什么是原子性、可见性、有序性?

21、什么是守护线程?有什么用?

22、一个线程运行时发生异常会怎样?

23、线程 yield()方法有什么用?

24、什么是重入锁?

25、Synchronized 有哪几种用法?

26、Fork/Join 框架是干什么的?

27、线程数过多会造成什么异常?

28、说说线程安全的和不安全的集合。

29、什么是 CAS 算法?在多线程中有哪些应用。

30、怎么检测一个线程是否拥有锁?

31、Jdk 中排查多线程问题用什么命令?

32、线程同步需要注意什么?

33、线程 wait()方法使用有什么前提?

34、Fork/Join 框架使用有哪些要注意的地方?

35、线程之间如何传递数据?

36、保证"可见性"有哪几种方式?

37、说几个常用的 Lock 接口实现锁。

38、ThreadLocal 是什么?有什么应用场景?

39、ReadWriteLock 有什么用?

40、FutureTask 是什么?

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

42、不可变对象对多线程有什么帮助?

43、多线程上下文切换是什么意思?

44、Java 中用到了什么线程调度算法?

45、Thread.sleep(0)的作用是什么?

46、Java 内存模型是什么,哪些区域是线程共享的,哪些是不共享的?

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

48、Hashtable 的 size()方法为什么要做同步?

49、同步方法和同步块,哪种更好?

50、什么是自旋锁?

51、Runnable 和 Thread 用哪个好?

52、Java 中 notify 和 notifyAll 有什么区别?

53、为什么 wait/notify/notifyAll 这些方法不在 thread 类里面?

54、为什么 wait 和 notify 方法要在同步块中调用?

55、为什么你应该在循环中检查等待条件?

56、Java 中堆和栈有什么不同?

57、你如何在 Java 中获取线程堆栈?

58、如何创建线程安全的单例模式?

59、什么是阻塞式方法?

60、提交任务时线程池队列已满会时发会生什么?

为了不影响大家的阅读体验,这篇Java多线程的面试真题已经为大家打包好了,需要的小伙伴点赞+关注我后,【戳此处】即可获取,希望这份面试笔记可以帮助大小伙伴愉快的通过面试,当然以上的面试真题仅供参考!