目录
6.Java中一个字符占多少个字节,扩展再问int、 long、double占多少字节?
10.String str="hello world"和String str=new String("hello world")的区别?(高频考点)
11.StringBuffer和StringBuilder的区别是什么?性能对比?如何鉴定线程安全?(高频考点)
12.StringBuffer 和 StringBuilder 底层怎么实现的?(高频考点)
13.switch支持哪些数据类型?支持long么?(高频考点)
15.final、finnally、finalize的区别是什么?
16.Jdk1.8/Jdk1.7都分别新增了哪些特性?其他版本呢?(高频考点)
17.简单说下Lambda表达式,其解决了什么,相比java7的处理优化了什么?
18.有人说“Lambda能让Java程序慢30倍”,你怎么看?
22.假设引用了一个第三方的jar 有个类和我自己写的代码类一样,那么在类加载机制过程中是如何处理的?(高频考点)
23.Java提供了哪些IO方式? NIO如何实现多路复用?
1.HashMap相关put操作,get操作等流程?(高频考点)
3.HashMap如果我想要让自己的Object作为K应该怎么办?
5.HashMap1.7与HashMap1.8的区别,从数据结构上、Hash值的计算上、链表数据的插入方法、内部Entry类的实现上分析?
7.Hash1.7是基于数组和链表实现的,为什么不用双链表?HashMap1.8中引入红黑树的原因是?为什么要用红黑树而不是平衡二叉树?(高频考点)
8.HashMap、HashTable、ConcurrentHashMap的原理与区别?
9.HashMap和ConcurrentHashMap区别(高频考点)
10. ConcurrentHashMap的数据结构(高频考点)
13.Collections.SynchronizedCollection方法实现原理是什么?
14.Array和ArrayList有什么区别?使用时注意事项有哪些?
15.常用的集合类有哪些?比如List如何排序(最好说下底层上的实现)?(高频考点)
16.ArrayList和LinkedList内部的实现大致是怎样的?他们之间的区别和各自适应的场景是什么?
4.Java线程的状态?细说一下BLOCKED和WAITING有什么区别?(高频考点)
7.Java程序中启动一个线程是用run()还是start()?
8.Thread的start方法调用两次会怎么样?Thread是如何保证start方法调用只有一次生效?(高频考点)
13.volatile与synchronized的区别是什么?volatile作用(高频考点)
15.Atomic类如何保证原子性(CAS操作)(高频考点)
16.AtomicInteger、AtomicBoolean这些类之所以在高并发时高效,共同的原因是?
17.关于 Atomic 类中的主要变量如下,其使用了 volatile 关键字进行修饰。你知道它在源码中的主要意义是?(高频考点)
19.比较和替换是两个动作,CAS 是如何保证这两个操作的原子性呢?
21.无锁 VS 偏向锁 VS 轻量级锁 VS 重量级锁,解释锁升级?(高频考点)
22.乐观锁 VS 悲观锁?公平锁 VS 非公平锁?独享锁 VS 共享锁?
24.为什么读多写少的情况,就适合使用乐观锁呢?悲观锁在读多写少的情况下,不也是有很少的冲突吗?(高频考点)
26.用java 代码实现一个死锁用例,说说怎么解决死锁问题?回到用例代码下,如何解决死锁问题呢?(高频考点)
29.ReentrantLock底层公平锁和非公平锁的原理(高频考点)
32.除了用Object.wait和Object.notifyAll来实现线程间的交互外,你还会常用哪些来实现?
34.ThreadLocal为什么要使用弱引用和内存泄露问题(高频考点)
35.ThreadLocal怎么解决内存泄露的问题?(高频考点)
39.核心线程池ThreadPoolExecutor的参数/常见线程池的创建参数是什么样的?(高频考点)
41.实现一个自定义的ThreadFactory的作用通常是?
43.ThreadPoolExecutor的工作流程(高频考点)
44.ScheduledThreadPoolExecutor中的使用的是什么队列?内部如何实现任务排序的?
45.线程池的运行逻辑,FixedThreadPool、CachedThreadPool的原理(高频考点)
46.用Executors.newCachedThreadPool创建的线程池,在运行的过程中有可能产生的风险是?
47.阻塞队列ArrayBlockingQueue、LinkedBlockingQueue分析(高频考点)
48.请合理的使用Queue来实现一个高并发的生产/消费的场景,给些核心的代码片段。
50.JUC下的常见类的使用,take、poll的区别,put、offer的区别?
51.Future原理,其局限性是什么?并说说CompletableFuture核心原理?
52.你是否了解fork/join(基本思想)?在工作中是如何使用的?说说他们的优势是什么?(高频考点)
53.Java线程池的调优经验有哪些?(线程池的合理配置)(高频考点)
54.一个请求中,计算操作需要50ms,db操作需要100ms,对于一台8核的机器来说,如果要求cpu利用率达到100%,如何设置线程数?(高频考点)
55.如果系统中不同的请求对应的cpu时间和io时间都不同,那怎么设置线程数量?(高频考点)
56.线程池核心数20,最大600,阻塞队列200,当QPS200(注意是qps)的时候,请求是调第三方阻塞超时,请问怎么提高它的吞吐量(注意不能加机器)?(高频考点)
57.当前线程池是200,线程单次处理请求20ms,那么理论上单节点的qps 是多少呢?
58.多线程对Long数据进行加和会存在什么问题?如何解决?
2.后台服务出现明显“变慢”,谈谈你的诊断思路?(高频考点)
4.在Java程序运行阶段,可以用什么命令行工具来查看当前Java程序的一些启动参数值,例如Heap Size等。
5.用什么命令行工具可以查看运行的Java程序的GC状况,请具体写出命令行格式。(高频考点)
6.用什么工具,可以在Java程序运行的情况下跟踪某个方法的执行时间,请求参数信息等,并请解释下工具实现的原理。
7.当一个Java程序接收请求,很长时间都没响应的话,通常你会怎么去排查这种问题?
干货分享,感谢您的阅读!背景互联网大厂高频面试题基本总结回顾(含笔试高频算法整理)
(一)Java基础高频知识考点
针对人员:
1.全部人员都适用;
2.正式员工:针对应届+工作1-3年的面试者,本部分可部分考察;