如下为你们整理了今年一线大厂面试被问频率较高的多线程面试题,因为本人的见识局限性,因此可能不是很全面,也欢迎你们在后面留言补充,谢谢。面试
一、什么是线程?
二、什么是线程安全和线程不安全?
三、什么是自旋锁?
四、什么是Java内存模型?
五、什么是CAS?
六、什么是乐观锁和悲观锁?
七、什么是AQS?
八、什么是原子操做?在Java Concurrency API中有哪些原子类(atomic classes)?
九、什么是Executors框架?
十、什么是阻塞队列?如何使用阻塞队列来实现生产者-消费者模型?
十一、什么是Callable和Future?
十二、什么是FutureTask?
1三、什么是同步容器和并发容器的实现?
1四、什么是多线程?优缺点?
1五、什么是多线程的上下文切换?
1六、ThreadLocal的设计理念与做用?
1七、ThreadPool(线程池)用法与优点?
1八、Concurrent包里的其余东西:ArrayBlockingQueue、CountDownLatch等等。
1九、synchronized和ReentrantLock的区别?
20、Semaphore有什么做用?
2一、Java Concurrency API中的Lock接口(Lock interface)是什么?对比同步它有什么优点?
2二、Hashtable的size()方法中明明只有一条语句”return count”,为何还要作同步?
2三、ConcurrentHashMap的并发度是什么?
2四、ReentrantReadWriteLock读写锁的使用?
2五、CyclicBarrier和CountDownLatch的用法及区别?
2六、LockSupport工具?
2七、Condition接口及其实现原理?
2八、Fork/Join框架的理解?
2九、wait()和sleep()的区别?
30、线程的五个状态(五种状态,建立、就绪、运行、阻塞和死亡)?
3一、start()方法和run()方法的区别?
3二、Runnable接口和Callable接口的区别?
3三、volatile关键字的做用?
3四、Java中如何获取到线程dump文件?
3五、线程和进程有什么区别?
3六、线程实现的方式有几种(四种)?
3七、高并发、任务执行时间短的业务怎样使用线程池?并发不高、任务执行时间长的业务怎样使用线程池?并发高、业务执行时间长的业务怎样使用线程池?
3八、若是你提交任务时,线程池队列已满,这时会发生什么?
3九、锁的等级:方法锁、对象锁、类锁?
40、若是同步块内的线程抛出异常会发生什么?
4一、并发编程(concurrency)并行编程(parallellism)有什么区别?
4二、如何保证多线程下 i++ 结果正确?
4三、一个线程若是出现了运行时异常会怎么样?
4四、如何在两个线程之间共享数据?
4五、生产者消费者模型的做用是什么?
4六、怎么唤醒一个阻塞的线程?
4七、Java中用到的线程调度算法是什么
4八、单例模式的线程安全性?
4九、线程类的构造方法、静态块是被哪一个线程调用的?
50、同步方法和同步块,哪一个是更好的选择?
关注如下公众号回复 "多线程" 获取所有面试题整理及参考答案。算法
