- 1.什么是进程?是什么线程?进程和线程的关系?
- 2.并行和并发的区别?
- 3.多线程的优缺点(为什么使用多线程、多线程会引发什么问题)
- 4.线程的上下文切换
- 5.Java中守护线程和用户线程的区别?
- 6.线程死锁是如何产生的,如何避免
- 7.用Java实现死锁,并给出避免死锁的解决方案
- 8.Java中的死锁、活锁、饥饿有什么区别?
- 9.线程的生命周期和状态
- 10.创建线程一共有哪几种方法?
- 11.runnable 和 callable 有什么区别?
- 12.线程的run()和start()有什么区别?为什么调用start()方法时会执行run()方法,而不直接执行run()方法?
- 13.线程同步以及线程调度相关的方法有哪些?
- 14.线程的sleep()方法和yield()方法有什么不同?
- 15.sleep()方法和wait()方法的区别?
- 16.wait()方法一般在循环块中使用还是if块中使用?
- 17.线程通信的方法有哪些?
- 18.为什么wait()、notify()、notifyAll()被定义在Object类中而不是在Thread类中?
- 19.为什么wait(),notify()和notifyAll()必须在同步方法或者同步块中被调用?
- 20.为什么Thread类的sleep()和yield()方法是静态的?
- 21.如何停止一个正在运行的线程?
- 22.如何唤醒一个阻塞的线程?
- 23.Java如何实现两个线程之间的通信和协作?
- 24.同步方法和同步方法块哪个效果更好?
- 25.什么是线程同步?什么是线程互斥?他们是如何实现的?
- 26.在Java程序中如何保证线程的运行安全?
- 27.线程类的构造方法、静态块是被哪个线程调用的?
- 28.一个线程运行时异常会发生什么?线程数量过多会造成什么异常?
- 29.三个线程T1、T2、T3,如何让他们按顺序执行?
- 30.什么是synchronized关键字?
- 31.Java内存的可见性
- 32.synchronized关键字三大特性是什么?
- 33.synchronized关键字可以实现什么类型的锁?
- 34.synchronized关键字的使用方法
- 35.synchronized关键字的底层原理
- 36.jdk1.6为什么要对synchronized进行优化?做了哪些优化?
- 37.了解锁消除吗?了解锁粗化吗?
- 38.当线程1进入到一个对象的synchronized方法A后,线程2是否可以进入到此对象的synchronized方法B?
- 39.synchronized和volatile的区别?
- 40.synchronized和Lock的区别?
- 41.volatile的作用是什么?volatile的特性有哪些?
- 42.Java内存的可见性问题
- 43.为什么代码会重排序?
- 44.重排序会引发什么问题?
- 45.as-if-serial规则和happens-before规则的区别?
- 46.voliatile的实现原理?volatile实现内存可见性原理?
- 47.volatile如何实现有序性
- 48.编译器对内存屏障插入策略的优化
- 49.volatile能使一个非原子操作变成一个原子操作吗?
- 50.volatile和synchronized的区别?
- 51.什么是ConcurrentHashMap?相比于HashMap和HashTable有什么优势?
- 52.java中ConcurrentHashMap是如何实现的?
- 53.ConcurrentHashMap结构中变量使用volatile和final修饰有什么作用?
- 54.ConcurrentHashMap有什么缺点?
- 55.ConcurrentHashMap默认初始容量是多少?每次扩容为原来的几倍?
- 56.ConCurrentHashMap的key,value是否可以为null?为什么?HashMap中的key、value是否可以为null?
- 57.ConCurrentHashmap在JDK1.8中,什么情况下链表会转化为红黑树?
- 58.ConcurrentHashMap在JDK1.7和JDK1.8版本中的区别?
- 59.ConcurrentHashMap迭代器是强一致性还是弱一致性?
- 60.什么是ThreadLocal?有哪些应用场景?
- 61.ThreadLocal原理和内存泄露?
- 62.什么是线程池?为什么使用线程池?
- 63.线程池创建的几种方法
- 64.ThreadPoolExecutor构造函数的重要参数分析
- 65.ThreadPoolExecutor的饱和策略(拒绝策略)
- 66.线程池的执行流程
- 67.execute()方法和submit()方法的区别
- 68.什么是CAS?
- 69.CAS存在的问题及优点
- 70.Atomic原子类
- 71.什么是AQS?AQS的原理是什么?
- 72.AQS的资源共享方式有哪些?
- 73.如何使用AQS自定义同步器?
73.如何使用AQS自定义同步器?
- 悲观锁:synchronized关键字实现的是悲观锁,每次访问共享资源时都会上锁。
- 非公平锁:synchronized关键字实现的是非公平锁,即线程获取锁的顺序并不一定是按照线程阻塞的顺序。
- 可重入锁:synchronized关键字实现的是可重入锁,即已经获取锁的线程可以再次获取锁。
- 独占锁或者排他锁:synchronized关键字实现的是独占锁,即该锁只能被一个线程所持有,其他线程均被阻塞。
本站链接:https://www.mianshi.online,如需勘误或投稿,请联系微信:lurenzhang888
点击面试手册,获取本站面试手册PDF完整版