如何判断 Java 工程师的基础知识是否扎实?
我来给你出几道大题,能答对70%,你就算基础扎实了。
| 第一部分 Java基础(27) | 
| 1. 程序本质:代码是如何被执行的?CPU、操作系统、虚拟机各司何职? | 
| 2. 基础语法:从CPU角度看变量、数组、类型、运算、跳转、函数等语法 | 
| 3. 引用类型:同样都是存储地址,为何Java引用比C/C++指针更安全? | 
| 4. 基本类型:既然Java一切皆对象,那又为何要保留int等基本类型? | 
| 5. 位运算:>>>和>>有何区别?(原码/反码/补码、算术位移/逻辑位移) | 
| 6. 浮点数:计算机如何用二进制表示浮点数?为何0.1+0.1不等于0.2? | 
| 7. 字符:为何C/C++中char占1个字节,而Java中char占2个字节? | 
| 8. 字符串:请解释String类用到的三大技术:压缩、常量池、不可变 | 
| 9. 对象:请描述一下Java对象的内存结构,以及如何统计对象大小? | 
| 10. 关键字:静态内部类实现的单例如何做到线程安全且可延迟加载? | 
| 11. 容器:为什么不推荐在项目中使用Vector、Stack、HashTable? | 
| 12. 容器工具类:TimSort和DualPivotQuickSort的实现原理和区别 | 
| 13. HashMap(上):为何HashMap中数组的大小必须是2的幂次方? | 
| 14. HashMap(下):为何链表树化的阈值为8,默认装载因子是0.75? | 
| 15. LinkedHashMap:如何使用LinkedHashMap实现LRU缓存? | 
| 16. 迭代器:为什么使用迭代器遍历容器的同时修改容器会出错? | 
| 17. 异常(上):在项目开发中如何正确的定义、处理、打印异常? | 
| 18. 异常(下):高并发下异常太多导致程序变慢的核心原因是什么? | 
| 19. io类库:http://java.io类库如此庞大,怎么才能全面系统的掌握它? | 
| 20. nio类库:BIO、NIO、AIO三种Java I/O模型的实现原理和区别 | 
| 21. 高速I/O(上):普通的I/O读写流程都存在哪些性能问题? | 
| 22. 高速I/O(下):mmap和零拷贝是如何提高I/O读写速度的? | 
| 23. 泛型:为什么C++泛型支持int等基本类型而Java泛型不支持呢? | 
| 24. 反射:为什么通过反射创建对象要比使用new创建对象慢? | 
| 25. 注解:注解的配置方式相对于XML配置文件有什么优缺点? | 
| 26. 动态代理:为什么基于JDK实现的动态代理要求原始类有接口? | 
| 27. 函数式编程:函数接口、Lambda表达式、方法引用、Stream流 | 
| 第二部分 多线程(27) | 
| 28. 线程概述:有了进程为什么还要有线程?线程越多执行就越快吗? | 
| 29. 线程模型:线程模型有哪几种?Java线程是基于哪种模型实现的? | 
| 30. JMM(上):CPU缓存和指令重排给多线程编程带来哪些问题? | 
| 31. JMM(中):如何解决多线程中的可见性、原子性、有序性问题? | 
| 32. JMM(下):既然CPU支持缓存一致性协议,为何还有可见性问题? | 
| 33. 线程安全、临界区、竞态:如何分析一段代码是否线程安全? | 
| 34. synchronized(上):线程释放锁之后,如何通知其他线程获取锁? | 
| 35. synchronized(下):Java对synchronized进行了哪些性能优化? | 
| 36. Lock(上):相比Java synchronized,JUC Lock有什么优势? | 
| 37. Lock(中):如何使用AQS(抽象队列同步器)实现JUC Lock? | 
| 38. Lock(下):ReadWriteLock的锁升级与锁降级及其底层实现原理 | 
| 39. 死锁、活锁、饥饿:如何实现Java多线程死锁检测和撤销? | 
| 40. CAS:如何不使用锁实现AQS中的线程安全的等待队列? | 
| 41. 原子类:CAS的ABA问题是如何产生的以及如何解决? | 
| 42. 累加器:如何用数据分片、哈希优化、去伪共享等提高累加性能? | 
| 43. ThreadLocal:ThreadLocal相对于局部变量有何特殊应用场景? | 
| 44. 条件变量:为什么使用条件变量前需要先加锁? | 
| 45. 信号量:如何使用信号量来限制并发执行某个接口的线程数? | 
| 46. 锁存器和栅栏:如何编程测试接口在不同并发下的性能? | 
| 47. 并发容器:如何实现线程安全的数组、链表、哈希表等常用数据结构? | 
| 48. 写时复制:为什么JUC只支持数组类型的写时复制并发容器? | 
| 49. 阻塞等待:如何实现支持阻塞读写的线程安全队列(阻塞并发队列)? | 
| 50. 分段加锁:HashMap线程不安全原因及ConcurrentHashMap实现原理 | 
| 51. 线程状态:为何synchronized和Lock这两种锁对应的线程状态不同? | 
| 52. 线程中断:如何安全地提前终止正在执行业务逻辑的线程? | 
| 53. 线程池:线程池开多大最合适?为什么Redis单线程执行命令? | 
| 54. 线程执行框架:如何获取一个线程所执行的代码的运行结果? | 
| 第三部分 JVM(10) | 
| 55. 编译执行:Java代码的执行效率真的比C++等编译型语言低吗? | 
| 56. JIT编译:请解释下方法内联、逃逸分析等动态编译优化策略 | 
| 57. 类加载:双亲委派加载机制存在的意义是什么? | 
| 58. 内存分区:JVM内存模型中有几个分区?都是做什么用的? | 
| 59. 可达性分析:虚拟机是如何判断一个对象是否可以被回收的? | 
| 60. 垃圾回收算法:同为垃圾回收,为何FullGC要比YoungGC慢很多? | 
| 61. 垃圾回收器(上):如何在项目中选择合适的垃圾回收器? | 
| 62. 垃圾回收器(下):CMS和G1的并发垃圾回收是如何实现的? | 
| 63. JVM性能优化:多久一次、一次多久FullGC和YoungGC才算正常? | 
| 64. JVM问题排查:使用jstat、jmap等工具排查OOM等JVM问题 | 
掌握了上面这些,你基本上可以吊打面试官了。
这些我都整理成30万字的完整讲解
CodeCrush-跟着小争哥学技术关注我,接下来,我会在知乎上以专栏的形式持续更新以上问题的答案。
一周三更(数据结构与算法、刷题、面试、Java、系统设计、架构),关注我不错过精彩内容
@前Google工程师小争哥






