Java并发编程面试题 (堪称全网霸榜总结)
文章目录
基础知识
1.为什么要使用并发编程2.多线程应用场景
3.并发编程有什么缺点
4.并发编程三个必要因素是什么?
5.在 Java 程序中怎么保证多线程的运行安全?
6.并行和并发有什么区别?
7.什么是多线程
8.多线程的好处
9.多线程的劣势:
10.线程和进程区别
11.什么是上下文切换?
12.守护线程和用户线程有什么区别呢?
13.如何在 Windows 和 Linux 上查找哪个线程cpu利用率最高?
14.什么是线程死锁
15.形成死锁的四个必要条件是什么
16.如何避免线程死锁
17.创建线程的四种方式
18.说一下 runnable 和 callable 有什么区别
19.线程的 run()和 start()有什么区别?
20.为什么我们调用 start() 方法时会执行 run() 方法,为什么我们不能直接调用 run() 方法?
21.什么是 Callable 和 Future?
22.什么是 FutureTask
23.线程的状态
24.Java 中用到的线程调度算法是什么?
25.线程的调度策略
26.什么是线程调度器(Thread Scheduler)和时间分片(Time Slicing )?
27.请说出与线程同步以及线程调度相关的方法。
28.sleep() 和 wait() 有什么区别?
29.你是如何调用 wait() 方法的?使用 if 块还是循环?为什么?
30.为什么线程通信的方法 wait(), notify()和 notifyAll()被定义在 Object 类里?
31.为什么 wait(), notify()和 notifyAll()必须在同步方法或者同步块中被调用?
32.Thread 类中的 yield 方法有什么作用?
33.为什么 Thread 类的 sleep()和 yield ()方法是静态的?
34.线程的 sleep()方法和 yield()方法有什么区别?
35.如何停止一个正在运行的线程?
36.Java 中 interrupted 和 isInterrupted 方法的区别?
37.什么是阻塞式方法?
38.Java 中你怎样唤醒一个阻塞的线程?
39.notify() 和 notifyAll() 有什么区别?
40.如何在两个线程间共享数据?
41.Java 如何实现多线程之间的通讯和协作?
42.同步方法和同步块,哪个是更好的选择?
43.什么是线程同步和线程互斥,有哪几种实现方式?
44.在监视器(Monitor)内部,是如何做线程同步的?程序应该做哪种级别的同步?
45.如果你提交任务时,线程池队列已满,这时会发生什么
46.什么叫线程安全?servlet 是线程安全吗?
47.在 Java 程序中怎么保证多线程的运行安全?
48.你对线程优先级的理解是什么?
49.线程类的构造方法、静态块是被哪个线程调用的
50.Java 中怎么获取一份线程 dump 文件?你如何在 Java 中获取线程堆栈?
51.一个线程运行时发生异常会怎样?
52.Java 线程数过多会造成什么异常?
53.多线程的常用方法
并发理论
1.Java中垃圾回收有什么目的?什么时候进行垃圾回收?
2.线程之间如何通信及线程之间如何同步
3.Java内存模型
4.如果对象的引用被置为null,垃圾收集器是否会立即释放对象占用的内存?
5.finalize()方法什么时候被调用?析构函数(finalization)的目的是什么?
6.什么是重排序
7.重排序实际执行的指令步骤
8.重排序遵守的规则
9.as-if-serial规则和happens-before规则的区别
10.并发关键字 synchronized ?
11.说说自己是怎么使用 synchronized 关键字,在项目中用到了吗
12.单例模式了解吗?给我解释一下双重检验锁方式实现单例模式!”
13.说一下 synchronized 底层实现原理?
14.synchronized可重入的原理
15.什么是自旋
16.多线程中 synchronized 锁升级的原理是什么?
17.线程 B 怎么知道线程 A 修改了变量
18.当一个线程进入一个对象的 synchronized 方法 A 之后,其它线程是否可进入此对象的 synchronized 方法 B?
19.synchronized、volatile、CAS 比较
20.synchronized 和 Lock 有什么区别?
21.synchronized 和 ReentrantLock 区别是什么?
22.volatile 关键字的作用
23.Java 中能创建 volatile 数组吗?
24.volatile 变量和 atomic 变量有什么不同?
25.volatile 能使得一个非原子操作变成原子操作吗?
26.synchronized 和 volatile 的区别是什么?
27.final不可变对象,它对写并发应用有什么帮助?
28.Lock 接口和synchronized 对比同步它有什么优势?
29.乐观锁和悲观锁的理解及如何实现,有哪些实现方式?
30.什么是 CAS
31.CAS 的会产生什么问题?
32.什么是原子类
33.原子类的常用类
34.说一下 Atomic的原理?
35.死锁与活锁的区别,死锁与饥饿的区别?
2.线程之间如何通信及线程之间如何同步
3.Java内存模型
4.如果对象的引用被置为null,垃圾收集器是否会立即释放对象占用的内存?
5.finalize()方法什么时候被调用?析构函数(finalization)的目的是什么?
6.什么是重排序
7.重排序实际执行的指令步骤
8.重排序遵守的规则
9.as-if-serial规则和happens-before规则的区别
10.并发关键字 synchronized ?
11.说说自己是怎么使用 synchronized 关键字,在项目中用到了吗
12.单例模式了解吗?给我解释一下双重检验锁方式实现单例模式!”
13.说一下 synchronized 底层实现原理?
14.synchronized可重入的原理
15.什么是自旋
16.多线程中 synchronized 锁升级的原理是什么?
17.线程 B 怎么知道线程 A 修改了变量
18.当一个线程进入一个对象的 synchronized 方法 A 之后,其它线程是否可进入此对象的 synchronized 方法 B?
19.synchronized、volatile、CAS 比较
20.synchronized 和 Lock 有什么区别?
21.synchronized 和 ReentrantLock 区别是什么?
22.volatile 关键字的作用
23.Java 中能创建 volatile 数组吗?
24.volatile 变量和 atomic 变量有什么不同?
25.volatile 能使得一个非原子操作变成原子操作吗?
26.synchronized 和 volatile 的区别是什么?
27.final不可变对象,它对写并发应用有什么帮助?
28.Lock 接口和synchronized 对比同步它有什么优势?
29.乐观锁和悲观锁的理解及如何实现,有哪些实现方式?
30.什么是 CAS
31.CAS 的会产生什么问题?
32.什么是原子类
33.原子类的常用类
34.说一下 Atomic的原理?
35.死锁与活锁的区别,死锁与饥饿的区别?
浅程池
1.什么是线程池?
2.线程池作用?
3.线程池有什么优点?
4.什么是ThreadPoolExecutor?
5.什么是Executors?
6.线程池四种创建方式?
7.在 Java 中 Executor 和 Executors 的区别?
8.四种构建线程池的区别及特点?
1). newCachedThreadPool
2).newFixedThreadPool
3).newScheduledThreadPool
4).newSingleThreadExecutor
9.线程池都有哪些状态?
10.线程池中 submit() 和 execute() 方法有什么区别?
11.什么是线程组,为什么在 Java 中不推荐使用?
12.ThreadPoolExecutor饱和策略有哪些?
13.如何自定义线程线程池?
14.线程池的执行原理?
15.如何合理分配线程池大小?
16.什么是CPU密集
17.什么是IO密集
18.分配CPU和IO密集:
19.精确来说的话的话:
2.线程池作用?
3.线程池有什么优点?
4.什么是ThreadPoolExecutor?
5.什么是Executors?
6.线程池四种创建方式?
7.在 Java 中 Executor 和 Executors 的区别?
8.四种构建线程池的区别及特点?
1). newCachedThreadPool
2).newFixedThreadPool
3).newScheduledThreadPool
4).newSingleThreadExecutor
9.线程池都有哪些状态?
10.线程池中 submit() 和 execute() 方法有什么区别?
11.什么是线程组,为什么在 Java 中不推荐使用?
12.ThreadPoolExecutor饱和策略有哪些?
13.如何自定义线程线程池?
14.线程池的执行原理?
15.如何合理分配线程池大小?
16.什么是CPU密集
17.什么是IO密集
18.分配CPU和IO密集:
19.精确来说的话的话:
并发容器
1.你经常使用什么并发容器,为什么?
2.什么是Vector
3.ArrayList和Vector有什么不同之处?
4.为什么HashTable是线程安全的?
5.用过ConcurrentHashMap,讲一下他和HashTable的不同之处?
6.Collections.synchronized * 是什么?
7.Java 中 ConcurrentHashMap 的并发度是什么?
8.什么是并发容器的实现?
9.Java 中的同步集合与并发集合有什么区别?
10.SynchronizedMap 和 ConcurrentHashMap 有什么区别?
11.CopyOnWriteArrayList 是什么?
12.CopyOnWriteArrayList 的使用场景?
13.CopyOnWriteArrayList 的缺点?
14.CopyOnWriteArrayList 的设计思想?
2.什么是Vector
3.ArrayList和Vector有什么不同之处?
4.为什么HashTable是线程安全的?
5.用过ConcurrentHashMap,讲一下他和HashTable的不同之处?
6.Collections.synchronized * 是什么?
7.Java 中 ConcurrentHashMap 的并发度是什么?
8.什么是并发容器的实现?
9.Java 中的同步集合与并发集合有什么区别?
10.SynchronizedMap 和 ConcurrentHashMap 有什么区别?
11.CopyOnWriteArrayList 是什么?
12.CopyOnWriteArrayList 的使用场景?
13.CopyOnWriteArrayList 的缺点?
14.CopyOnWriteArrayList 的设计思想?
并发列队
1.什么是并发队列:
2.并发队列和并发集合的区别:
3.怎么判断并发队列是阻塞队列还是非阻塞队列
4.阻塞队列和非阻塞队列区别
5.常用并发列队的介绍:
6.并发队列的常用方法
2.并发队列和并发集合的区别:
3.怎么判断并发队列是阻塞队列还是非阻塞队列
4.阻塞队列和非阻塞队列区别
5.常用并发列队的介绍:
6.并发队列的常用方法
并发工具类
1.常用的并发工具类有哪些? 以上题集答案及更多大小厂面试真题资料获取方式: 评论扣111
Java面试总结汇总,整理了包括Java基础知识,集合容器,并发编程,JVM,常用开源框架Spring,MyBatis,数据库,中间件等,包含了作为一个 Java工程师在面试中需要用到或者可能用到的绝大部分知识。欢迎大家阅读,本人见识有限,写的博客难免有错误或者疏忽的地方,还望各位大佬指点,在此表示感激不尽。文章持续更新中…