Java面试题【并发编程篇】
-
- 1. 线程与进程
- 2. 多线程的几种实现方式,什么是线程安全
- 3. volatile的原理、作用,能代替锁么
- 4. 画一个线程的生命周期状态图
- 5. 什么是Future和FutureTask
- 6. sleep和wait的区别
- 7. sleep和sleep(0)的区别
- 8. Lock与Synchronized的区别
- 9. synchronized的原理是什么,一般用在什么地方(比如加在静态方法和非静态方法的区别,静态方法和非静态方法同时执行的时候会有影响吗),解释以下名词:重排序,自旋锁,偏向锁,轻量级锁,可重入锁,公平锁,非公平锁,乐观锁,悲观锁。
- 10. 用过哪些原子类,他们的原理是什么
- 11. JUC下研究过哪些并发工具,讲讲原理
- 12. 用过线程池吗,如果用过,请说明原理,并说说newCache和newFixed有什么区别,构造函数的各个参数的含义是什么,比如coreSize,maxsize等
- 13. 线程池的关闭方式有几种,各自的区别是什么
- 14. 假如有一个第三方接口,有很多个线程去调用获取数据,现在规定每秒钟最多有10个线程同时调用它,如何做到
- 15. spring的controller是单例还是多例,怎么保证并发的安全
- 16. 用三个线程按顺序循环打印abc三个字母,比如abcabcabc
- 17. ThreadLocal用过么,用途是什么,原理是什么,用的时候要注意什么
- 18. 如果让你实现一个并发安全的链表,你会怎么做
- 19. 有哪些无锁数据结构,他们实现的原理是什么
- 20. 讲讲java同步机制的wait和notify
- 21. CAS机制是什么,如何解决ABA问题
- 22. 多线程如果线程挂住了怎么办
- 23. 对AbstractQueuedSynchronizer了解多少,讲讲加锁和解锁的流程,独占锁和公平所加锁有什么不同
- 24. 使用synchronized修饰静态方法和非静态方法有什么区别
- 25. 简述ConcurrentLinkedQueue和LinkedBlockingQueue的用处和不同之处
- 26. 导致线程死锁的原因?怎么避免线程死锁
- 27. 用过读写锁吗,原理是什么,一般在什么场景下用
- 28. 开启多个线程,如果保证顺序执行,有哪几种实现方式,或者如何保证多个线程都执行完再拿到结果
- 29. 延迟队列的实现方式,delayQueue和时间轮算法的异同
1. 线程与进程
进程
一个在内存中运行的应用程序。每个进程都有自己独立的一块内存空间,一个进程可以有多个线程,比如在Windows系统中,一个运行的xx.exe就是一个进程。
线程
进程中的一个执行任务(控制单元),负责当前进程中程序的执行。一个进程至少有一个线程,一个进程可以运行多个线程,多个线程可共享数据。
线程具有许多传统进程所具有的特征,故又称为轻型进程(Light—Weight Process)或进程元;而把传统的进程称为重型进程(Heavy—Weight Process)。在引入了线程的操作系统中,通常一个进程都有若干个线程,至少包含一个线程。
根本区别: 进程是操作系统资源分配的基本单位,而线程是处理器任务调度和执行的基本单位。
资源开销和内存分配:每个进程都有独立的代码和数据空间(程序上下文),进程之间的切换会有较大的开销;线程可以看做轻量级的进程,同一类线程共享代码和数据空间,每个线程都有自己独立的运行栈和程序计数器(PC),线程之间切换的开销小。
包含关系: 线程是进程的一部分。一个进程至少有一个线程,一个进程可以运行多个线程。
影响关系: 一个进程崩溃后,在保护模式下不会对其他进程产生影响,但是一个线程崩溃整个进程都死掉。所以多进程要比多线程健壮。
执行过程: 每个独立的进程有程序入口、顺序执行序