多线程面试题全面总结
Posted 风某人~Wind
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了多线程面试题全面总结相关的知识,希望对你有一定的参考价值。
学会以下这些面试题,多线程面试再也不用愁。
- 什么是线程?
- 线程和进程有什么区别?
- 线程实现的方式有几种(四种)?
- Runnable接口和Callable接口的区别?
- start()方法和run()方法的区别?
- 线程的五个状态(五种状态,创建、就绪、运行、阻塞和死亡)?
- 怎么唤醒一个阻塞的线程?
- 什么是线程安全和线程不安全?
- 什么是多线程?优缺点?
- 什么是多线程的上下文切换?
- Java中用到的线程调度算法是什么
- 一个线程如果出现了运行时异常会怎么样?
- 线程类的构造方法、静态块是被哪个线程调用的?
- 锁的等级:方法锁、对象锁、类锁?
- volatile关键字的作用?
- volatile和synchronized的区别?
- 如果同步块内的线程抛出异常会发生什么?
- 同步方法和同步块,哪个是更好的选择?
- 如何保证多线程下 i++ 结果正确?
- 什么是原子操作?在Java Concurrency API中有哪些原子类(atomic classes)?
- 什么是synchronized?
- 什么是自旋锁?
- 什么是乐观锁和悲观锁?
- Java Concurrency API中的Lock接口(Lock interface)是什么?对比同步它有什么优势?
- synchronized和ReentrantLock的区别?
- ReentrantReadWriteLock读写锁的使用?
- 什么是Java内存模型?
- 什么是AQS?
- 什么是CAS?
- 什么是Unsafe?
- wait()和sleep()的区别?
- 什么是Callable和Future?
- 什么是FutureTask?
- 什么是同步容器和并发容器的实现?
- 如何在两个线程之间共享数据?
- 生产者消费者模型的作用是什么?
- ThreadLocal的设计理念与作用?
- Concurrent包里的其他东西:ArrayBlockingQueue、CountDownLatch等等。
- 什么是阻塞队列?如何使用阻塞队列来实现生产者-消费者模型?
- Semaphore有什么作用?
- CyclicBarrier和CountDownLatch的用法及区别?
- LockSupport工具?
- Condition接口及其实现原理?
- Java中如何获取到线程dump文件?
- Hashtable的size()方法中明明只有一条语句”return count”,为什么还要做同步?
- HashMap、ConcurrentHashMap底层原理
- ConcurrentHashMap的并发度是什么?
- 并发编程(concurrency)并行编程(parallellism)有什么区别?
- 什么是Executors框架?
- Executors创建线程的几种方式?
- ThreadPoolExecutor和Executors类下面的线程池工具方法有什么区别?
- ThreadPoolExecutor中的七个参数分别含义?
- 线程池有哪些生命周期?
- ThreadPool(线程池)用法与优势?
- 高并发、任务执行时间短的业务怎样使用线程池?并发不高、任务执行时间长的业务怎样使用线程池?并发高、业务执行时间长的业务怎样使用线程池?
- 如果你提交任务时,线程池队列已满,这时会发生什么?
- Fork/Join框架的理解?
- Disruptor是什么结构来存储数据?
- 为什么说Disruptor是单机最快的队列?
- 如何检测死锁?怎么预防死锁?
有时间我会整理一下答案发出来,如果有更多的多线程的面试题欢迎补充。
以上是关于多线程面试题全面总结的主要内容,如果未能解决你的问题,请参考以下文章