2019年全网最热门的123个Java并发面试题总结

简介: 123个Java并发面试题,你遇到过哪些?

前言

并发编程几乎是所有互联网公司面试必问的问题,并发编程是Java程序员最重要的技能之一,也是最难掌握的一种技能。它要求编程者对计算机最底层的运作原理有深刻的理解,同时要求编程者逻辑清晰、思维缜密,这样才能写出高效、安全、可靠的多线程并发程序。
image

关于Java并发编程的知识总结了个思维导图,分享给大家
image

整理了网络上热门的123道Java并发面试题,看看你都遇到过哪些?

Java 并发编程(一)

1、在 java 中守护线程和本地线程区别?
2、线程与进程的区别?
3、什么是多线程中的上下文切换?
4、死锁与活锁的区别,死锁与饥饿的区别?
5、Java 中用到的线程调度算法是什么?
6、什么是线程组,为什么在 Java 中不推荐使用?
7、为什么使用 Executor 框架?
8、在 Java 中 Executor 和 Executors 的区别?
9、如何在 Windows 和 Linux 上查找哪个线程使用的 CPU 时间最长?
10、什么是原子操作?在 Java Concurrency API 中有哪些原子类(atomic classes)?
11、Java Concurrency API 中的 Lock 接口(Lock interface)是什么?对比同步它有什么优势?
12、什么是 Executors 框架?
13、什么是阻塞队列?阻塞队列的实现原理是什么?如何使用阻塞队列来实现生产者-消费者模型?
14、什么是 Callable 和 Future?
15、什么是 FutureTask?使用 ExecutorService 启动任务。
16、什么是并发容器的实现?
17、多线程同步和互斥有几种实现方法,都是什么?
18、什么是竞争条件?你怎样发现和解决竞争?
19、你将如何使用 thread dump?你将如何分析 Thread dump?
20、为什么我们调用 start()方法时会执行 run()方法,为什么我们不能直接调用 run()方法?
21、Java 中你怎样唤醒一个阻塞的线程?
22、在 Java 中 CycliBarriar 和 CountdownLatch 有什么区别?
23、什么是不可变对象,它对写并发应用有什么帮助?
24、什么是多线程中的上下文切换?
25、Java 中用到的线程调度算法是什么?
26、什么是线程组,为什么在 Java 中不推荐使用?
27、为什么使用 Executor 框架比使用应用创建和管理线程好?
28、java 中有几种方法可以实现一个线程?
29、如何停止一个正在运行的线程?
30、notify()和 notifyAll()有什么区别?
31、什么是 Daemon 线程?它有什么意义?
32、java 如何实现多线程之间的通讯和协作?
33、什么是可重入锁(ReentrantLock)?
34、当一个线程进入某个对象的一个 synchronized 的实例方法后,其它线程是否可进入此对象的其它方法?
35、乐观锁和悲观锁的理解及如何实现,有哪些实现方式?
36、SynchronizedMap 和 ConcurrentHashMap 有什么区别?
37、CopyOnWriteArrayList 可以用于什么应用场景?
38、什么叫线程安全?servlet 是线程安全吗?
39、volatile 有什么用?能否用一句话说明下 volatile 的应用场景?
40、为什么代码会重排序?
41、在 java 中 wait 和 sleep 方法的不同?
42、用 Java 实现阻塞队列
43、一个线程运行时发生异常会怎样?
44、如何在两个线程间共享数据?
45、Java 中 notify 和 notifyAll 有什么区别?
46、为什么 wait, notify 和 notifyAll 这些方法不在 thread 类里面?
47、什么是 ThreadLocal 变量?
48、Java 中 interrupted 和 isInterrupted 方法的区别?
49、为什么 wait 和 notify 方法要在同步块中调用?
50、为什么你应该在循环中检查等待条件?
51、Java 中的同步集合与并发集合有什么区别?
52、什么是线程池? 为什么要使用它?
53、怎么检测一个线程是否拥有锁?
54、你如何在 Java 中获取线程堆栈?
56、Thread 类中的 yield 方法有什么作用?
57、Java 中 ConcurrentHashMap 的并发度是什么?
58、Java 中 Semaphore 是什么?
59、Java 线程池中 submit() 和 execute()方法有什么区别?
60、什么是阻塞式方法?
61、Java 中的 ReadWriteLock 是什么?
62、volatile 变量和 atomic 变量有什么不同?
63、可以直接调用 Thread 类的 run ()方法么?
64、如何让正在运行的线程暂停一段时间?
65、你对线程优先级的理解是什么?
66 、 什 么 是 线 程 调 度 器 (Thread Scheduler) 和 时 间 分 片 (TimeSlicing )?
67、你如何确保 main()方法所在的线程是 Java 程序最后结束的线程?
68、线程之间是如何通信的?
69、为什么线程通信的方法 wait(), notify()和 notifyAll()被定义在Object 类里?
70、为什么 wait(), notify()和 notifyAll ()必须在同步方法或者同步块中被调用?
71、为什么 Thread 类的 sleep()和 yield ()方法是静态的?
72、如何确保线程安全?
73、同步方法和同步块,哪个是更好的选择?
74、如何创建守护线程?
75、什么是 Java Timer 类?如何创建一个有特定时间间隔的任务?
image

Java 并发编程(二)

1、并发编程三要素?
2、实现可见性的方法有哪些?
3、多线程的价值?
4、创建线程的有哪些方式?
5、创建线程的三种方式的对比?
6、线程的状态流转图
7、Java 线程具有五中基本状态
8、什么是线程池?有哪几种创建方式?
9、四种线程池的创建:
10、线程池的优点?
11、常用的并发工具类有哪些?
12、CyclicBarrier 和 CountDownLatch 的区别
13、synchronized 的作用?
14、volatile 关键字的作用.
15、什么是 CAS
16、CAS 的问题
17、什么是 Future?
18、什么是 AQS
19、AQS 支持两种同步方式:
20、ReadWriteLock 是什么
21、FutureTask 是什么
22、synchronized 和 ReentrantLock 的区别
23、什么是乐观锁和悲观锁
24、线程 B 怎么知道线程 A 修改了变量
25、synchronized、volatile、CAS 比较
26、sleep 方法和 wait 方法有什么区别?
27、ThreadLocal 是什么?有什么用?
28、为什么 wait()方法和 notify()/notifyAll()方法要在同步块中被调用
29、多线程同步有哪几种方法?
30、线程的调度策略
31、ConcurrentHashMap 的并发度是什么
32、Linux 环境下如何查找哪个线程使用 CPU 最长
33、Java 死锁以及如何避免?
34、死锁的原因
35、怎么唤醒一个阻塞的线程
36、不可变对象对多线程有什么帮助
37、什么是多线程的上下文切换
38、如果你提交任务时,线程池队列已满,这时会发生什么
39、Java 中用到的线程调度算法是什么
40 、 什 么 是 线 程 调 度 器 (Thread Scheduler) 和 时 间 分 片 (TimeSlicing)?
41、什么是自旋
42、Java Concurrency API 中的 Lock 接口(Lock interface)是什么?对比同步它有什么优势?
43、单例模式的线程安全性
44、Semaphore 有什么作用
45、Executors 类是什么?
46、线程类的构造方法、静态块是被哪个线程调用的
47、同步方法和同步块,哪个是更好的选择?
48、Java 线程数过多会造成什么异常?
image

上面的这些问题只是给大家一个借鉴作用,最主要的是给自己增加知识的储备,有备无患。
关于这123个热门的Java并发面试题总结了50多页pdf文档,关注我的公种浩 程序员追风 即可领取!
image
希望能帮助到你面试前的复习且找到一个好的工作,也节省大家在网上搜索资料的时间来学习。

最后

欢迎大家一起交流,喜欢文章记得关注我点赞转发哟,感谢支持!

相关文章
|
5天前
|
XML 缓存 Java
Java大厂面试题
Java大厂面试题
18 0
|
5天前
|
存储 安全 Java
Java大厂面试题
Java大厂面试题
11 0
|
5天前
|
存储 安全 Java
Java大厂面试题
Java大厂面试题
13 0
|
5天前
|
安全 Java
深入理解 Java 多线程和并发工具类
【4月更文挑战第19天】本文探讨了Java多线程和并发工具类在实现高性能应用程序中的关键作用。通过继承`Thread`或实现`Runnable`创建线程,利用`Executors`管理线程池,以及使用`Semaphore`、`CountDownLatch`和`CyclicBarrier`进行线程同步。保证线程安全、实现线程协作和性能调优(如设置线程池大小、避免不必要同步)是重要环节。理解并恰当运用这些工具能提升程序效率和可靠性。
|
6天前
|
安全 Java
就只说 3 个 Java 面试题 —— 02
就只说 3 个 Java 面试题 —— 02
19 0
|
6天前
|
存储 安全 Java
就只说 3 个 Java 面试题
就只说 3 个 Java 面试题
10 0
|
7天前
|
Java 开发者
Java中多线程并发控制的实现与优化
【4月更文挑战第17天】 在现代软件开发中,多线程编程已成为提升应用性能和响应能力的关键手段。特别是在Java语言中,由于其平台无关性和强大的运行时环境,多线程技术的应用尤为广泛。本文将深入探讨Java多线程的并发控制机制,包括基本的同步方法、死锁问题以及高级并发工具如java.util.concurrent包的使用。通过分析多线程环境下的竞态条件、资源争夺和线程协调问题,我们提出了一系列实现和优化策略,旨在帮助开发者构建更加健壮、高效的多线程应用。
7 0
|
8天前
|
存储 缓存 安全
Java并发基础之互斥同步、非阻塞同步、指令重排与volatile
在Java中,多线程编程常常涉及到共享数据的访问,这时候就需要考虑线程安全问题。Java提供了多种机制来实现线程安全,其中包括互斥同步(Mutex Synchronization)、非阻塞同步(Non-blocking Synchronization)、以及volatile关键字等。 互斥同步(Mutex Synchronization) 互斥同步是一种基本的同步手段,它要求在任何时刻,只有一个线程可以执行某个方法或某个代码块,其他线程必须等待。Java中的synchronized关键字就是实现互斥同步的常用手段。当一个线程进入一个synchronized方法或代码块时,它需要先获得锁,如果
24 0
|
16天前
|
Java 关系型数据库 MySQL
大厂面试题详解:Java抽象类与接口的概念及区别
字节跳动大厂面试题详解:Java抽象类与接口的概念及区别
40 0
|
16天前
|
存储 缓存 安全
【企业级理解】高效并发之Java内存模型
【企业级理解】高效并发之Java内存模型