Java并发-多线程面试(全面)
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. 如何检测死锁?怎么预防死锁?
52. ConcurrentModificationException 异常原因?
会逐步更新答案.....
Java并发-多线程面试(全面)的更多相关文章
- java并发多线程显式锁Condition条件简介分析与监视器 多线程下篇(四)
Lock接口提供了方法Condition newCondition();用于获取对应锁的条件,可以在这个条件对象上调用监视器方法 可以理解为,原本借助于synchronized关键字以及锁对象,配备了 ...
- java 并发多线程 锁的分类概念介绍 多线程下篇(二)
接下来对锁的概念再次进行深入的介绍 之前反复的提到锁,通常的理解就是,锁---互斥---同步---阻塞 其实这是常用的独占锁(排它锁)的概念,也是一种简单粗暴的解决方案 抗战电影中,经常出现为了阻止日 ...
- java 并发多线程显式锁概念简介 什么是显式锁 多线程下篇(一)
目前对于同步,仅仅介绍了一个关键字synchronized,可以用于保证线程同步的原子性.可见性.有序性 对于synchronized关键字,对于静态方法默认是以该类的class对象作为锁,对于实例方 ...
- Java并发多线程 - 并发工具类JUC
安全共享对象策略 1.线程限制 : 一个被线程限制的对象,由线程独占,并且只能被占有它的线程修改 2.共享只读 : 一个共享只读的对象,在没有额外同步的情况下,可以被多个线程并发访问, 但是任何线程都 ...
- Java并发多线程面试题 Top 50
不管你是新程序员还是老手,你一定在面试中遇到过有关线程的问题.Java语言一个重要的特点就是内置了对并发的支持,让Java大受企业和程序员的欢迎.大多数待遇丰厚的Java开发职位都要求开发者精通多线程 ...
- Java并发/多线程系列——初识篇
回到过去,电脑有一个CPU,一次只能执行一个程序.后来多任务处理意味着计算机可以同时执行多个程序(AKA任务或进程).这不是真的"同时".单个CPU在程序之间共享.操作系统将在运行 ...
- day 04 Java并发多线程
http://www.cnblogs.com/hellocsl/p/3969768.html?utm_source=tuicool&utm_medium=referralPS:而JVM 每遇到 ...
- Java并发(一)Java并发/多线程教程
在过去一台电脑只有单个CPU,并且在同一时间只能执行单个程序.后来出现的"多任务"意味着电脑在可以同时执行多个程序(AKA任务或者进程).虽然那并不是真正意义上的"同时& ...
- java并发多线程(摘自网络)
1. 进程和线程之间有什么不同? 一个进程是一个独立(self contained)的运行环境,它可以被看作一个程序或者一个应用.而线程是在进程中执行的一个任务.Java运行环境是一个包含了不同的类和 ...
随机推荐
- delphi 大文件的读写 使用 MapviewOffile
unit filemap; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, For ...
- 30.SSH配置文件模板和类库.md
目录 1.struts2 4.类库 1.struts2 1.<?xml version="1.0" encoding="UTF-8"?>2.< ...
- /src/log4j2.xml
<?xml version="1.0" encoding="UTF-8"?> <Configuration status="warn ...
- UMD编码规范
(function(global, factory){ typeof module === 'object' && typeof module.exports === 'object' ...
- HTTP是用来做什么的
(一)HTTP协议介绍 超文本传输协议(HTTP,HyperText Transfer Protocol)是互联网上应用最为广泛的一种网络协议.所有的WWW文件都必须遵守这个标准.设计HTTP最初的目 ...
- CentOS6.5安装MySQL5.7详细教程(本人6.3也行)
本文参考http://www.cnblogs.com/lzj0218/p/5724446.html 主要参考博文: https://segmentfault.com/a/119000000304949 ...
- Building Projects with Native Code
[Building Projects with Native Code] 1.安装Node(v4.0以上).Python2.JDK(v8.0以上). 添加 JAVA_HOME环境变量,指向 JDK 的 ...
- unity中Android环境变量配置
http://www.cnblogs.com/windytrees/p/7533477.html
- 解决pip下载速度慢
国外的pip源下载速度过慢,可以换成国内的源,这里换成豆瓣的源. 新建一个文件vim ~/.pip/pip.conf 内容为 [global]timeout = 6000index-url= http ...
- 六、Prototype 原型设计模式
需求:使用 new 生成实例需要指定类名,在不指定类的情况下生成实例 代码清单: 原型接口 Product: public interface Product extends Cloneable{ v ...