Java 工作两年多,我面试过的题目

2021-02-07 11:56:20 +08:00
 young1lin

以下下划线是我一定没遇到过的。其他的有些遇到过,有些有可能会遇到。内容有点多,更多的在 https://github.com/young1lin/notes/blob/master/Prepare%20for%20Interview/%E9%9D%A2%E8%AF%95%E9%97%AE%E9%A2%98%E7%AE%80%E5%8D%95%E6%B1%87%E6%80%BB.md

HashSet 的底层实现说下?为什么内置 HashMap ?说下它的数据结构,为什么 loadFactor 是 0.75 ?为什么要高位参与与运算?为什么它的 size 是 2 的 n 次方?为什么默认是 16 ?讲下它的扩容机制。什么时候转红黑树,为什么要转红黑树?为什么它是线程不安全的,它的哪些方法是线程不安全的?为什么会造成死循环? 1.8 是如何解决这个问题的?它的线程安全的实现有什么? ConcurrentHashMap 和 HashTable 有什么区别?说下它 1.7 和 1.8 的实现是什么?有什么区别?为什么要这么做?为什么说 ConcurrentHashMap 是线程安全的?它的 get 操作是有锁的吗?它是强一致性的吗?它为什么是弱一致性的? ConcurrentHashMap 1.7 和 1.8 是如何扩容的?sizeCtl 参数是干什么的,讲讲变换过程?为什么要用 volatile 修饰?说说它的功能?什么是 MESI 协议? CPU 原语是什么?什么是可见性? JMM 说说是什么?为什么要有 JMM ? Happened-before 是什么?它和 synchronized 的区别是什么?锁的升级与降级说下是什么?偏向锁是什么? Mark-Wrod 说下?锁的粒度是什么?锁消除了解吗?锁会被合并吗?什么时候会发生?你刚才说了 CAS,你能说下它是什么东西吗?为什么要引入 CAS ? ABA 问题是如何解决的? AQS 了解吗?它是如何实现的? CLH 又是什么? ReentrantLock 和 synchronized 区别是什么?为什么 ReetrantLock 能实现公平锁?默认构造器是公平锁吗?为什么不是? Copy-on-Write 了解吗? Fork/Join 又是什么?什么是线程,什么是协程?你刚才说了管程?你能说下这几个到底是做什么的吗?线程池说下参数,四种内置的拒绝策略,以及它的执行流程。你用过吗?为什么要这么设置参数? I/O 密集型应用和计算密集型应用如何设置其参数?你具体的业务线程池的参数是怎么设计的?为什么?测过吗?你定制化开发过吗?线程池预留了 3 个供子类扩展的方法你知道是哪三个吗?能做什么你知道吗? ThreadLocal 是什么?它为什么会造成内存泄漏?你实际开发中用到过吗? Spring 事务用这个干什么的?什么是事务的 SavePoint ?你知道死锁吗?如何解决死锁? sleep 和 wait 的区别是什么? BIO 、NIO 、AIO 是什么?说下区别,以及如何使用?了解 Netty 吗?如何解决粘包问题? ChannelPipeline 又是什么? ByteBuf 知道吗?读写指针又是什么?它和 mina 的区别是什么?它的 Zero-Copy ?了解过 FastThreadLocal 吗?它为什么比 ThreadLocal 快?有看过其中源码吗? Netty 解决了 NIO 类库的什么问题?空轮询又是什么? RPC 又是什么?序列化和反序列化又是什么?几个核心类说下。是干什么的?

你说你了解虚拟机,你知道虚拟机的运行时数据区吗?哪些是线程共享的,哪些是线程独有的?你了解 JVM 调优吗?调优过吗?为什么要这么设置?垃圾回收算法有几种?为什么要分代收集? Young 区说说它的分布结构,为什么 Eden 区 80%?为什么大对象直接进入老年代?控制的参数是什么?一个对象如果不是大对象,怎样才能进入老年代?控制的参数是什么?什么时候会发生 OOM ?你遇到过吗?怎么解决的?为什么低版本的 JDK 要把永久代内存调大点?默认大小是多少你知道吗?什么是 Major GC,什么是 Minor GC ?什么情况下会频繁 GC ?你查看过 GC 日志吗?什么时候回收对象?引用计数和可达性分析是什么?为什么 Java 使用后者? Python 使用前者?什么是 GCRoot ?什么时候对象不可达? Java 的四种引用说下,分别用在什么场景?你知道 JDK 源码哪里有用到 WeakReference 吗?什么是 STW ?什么是 Safepoint ?类加载的过程说下,什么时候优化,以及不同的时候的主要优化是什么?解语法糖是什么时候?为什么在编译的时候解语法糖?什么是双亲委派模型?可以破坏吗?各个 ClassLoader 加载哪部分类的?你自定义过 ClassLoader 吗?你说你用过 Jstack 诊断 CPU 使用率飙升的情况,说下具体步骤? Arthas 用过吗? Class 文件格式说下,什么是魔数,Class 文件的魔数是什么? JMX 了解吗?

ACID 说下是什么。你说你优化过 SQL,怎么优化的说下。like '%xx%',like '%xx',like 'xx%' 哪种情况会用到索引?说下 MySQL 执行流程。WAL(Write-Ahead Logging) 知道吗? redo log 和 undo log 是什么,它们作用说下。你说你改过 buffer_pool_size 等参数,为什么要改它?它里面的数据结构说下是什么?为什么冷热 3:7 ? join_buffer 你说你也改了,为什么?什么是驱动表和被驱动表?如何优化?你说你建了索引,什么是蔟集索引,什么是非蔟集索引?什么是回表?什么时候会索引失效?你的二级索引什么用得多?为什么优先使用普通索引,而不是唯一索引? MySQL 会死锁吗?什么是间隙锁?它会导致什么问题? MVCC 说下是什么? 4 种事务说下是什么?哪种或者哪几种事务隔离级别能避免幻读?能避免脏读?你说你还开启了 binlog,能说说是什么吗? canal 用过吗?说说它的原理。MySQL 主从模式如何开启?你是如何优化 SQL 的?上亿级别的数据你是如何优化分页的?为什么不建议在 MySQL 中使用分区机制?为什么删了数据还是磁盘空间不变?自增主键用完了会怎么样?如何解决这个问题?自增主键什么时候是不连续的?这样做的好处是什么?为什么推荐用自增主键? B+ Tree 又是什么?如何迁移数据库?为什么不建议使用外键?在高版本的 MySQL 中 count(1) 和 count(*) 区别是什么? order by 是如何工作的?分页机制又是什么? ACL 和 RBAC 是什么? grant 之后一定要刷新吗?视图用过吗?它的作用说下。视图和表的区别说下。存储过程写过吗?存储函数和存储过程的区别说下。NoSQL 用过吗? OceanBase 了解吗? HBase 了解吗?<u>HBase 有哪些坑,你碰到过吗?什么是 RegionServer ?</u>什么时候用 NoSQL,它能取代 RDBMS 吗?你说你用过 Elasticsearch,能说下它的请求执行过程吗?它的总体架构说下。它的插件你用过吗?你们的分词策略是什么?倒排索引说下是什么。

给二叉树后序和中序遍历,写前序遍历。手写个快排。翻转一下链表。O ( 1 )找出链表有环。DFS 找出二叉树搜索树第 k 大节点。

实现一个多线程类,并用该线程类实例化 3 个线程 A,B,C ; A 线程打印字符 A,B 线程打印字符 B,C 线程打印字符 C ;启动这 3 个线程,要求启动线程的顺序为 C 线程->B 线程->A 线程,并且最后输出内容为:A B C 。禁止使用 sleep 函数。阿里应该还有各种多线程打印的问题,这个得准备。

接下来应该是更高级的算法题目,至少是 LeetCode Menium 难度的,翻转链表确实有点初级,练个半个小时就搞定了。暂时还没碰到,碰到我也挂了。

你平时是怎么学习一门新技术的?

最近有看书吗?看的什么书?能和我讲讲吗?

你为什么离职?下一家公司的期望是什么?期望薪资?

10915 次点击
所在节点    Java
83 条回复
young1lin
2021-02-07 21:11:43 +08:00
@liupeng2579793 这是一部分,全部的在 Github 上面,Spring MVC 的我忘写了
young1lin
2021-02-07 21:14:22 +08:00
@aguesuka 我都说了,这是一块的问题,放到一块,如果是一个问题换一行,那这个就很长了
lifetimeporn
2021-02-07 21:25:53 +08:00
要开始爱上八股文,这样才能跳槽
ArJun
2021-02-07 21:29:08 +08:00
没觉得排版问题,问题是现在的 Java 面试就是这样,很臃肿,一堆什么乱七八糟的问题都问
young1lin
2021-02-07 21:45:08 +08:00
@yamasa 这还是基础的,太变态我还没写呢,真的离谱,我工作一年多的时候问我 Spring Bean 生命周期。V2ex 发不了,太多了,只能给 Github 链接了
Auster
2021-02-07 22:12:40 +08:00
像极了 A 厂的一二面。。。
redford42
2021-02-08 00:10:05 +08:00
尊重一下面试官,背下八股文
shmilypeter
2021-02-08 01:03:09 +08:00
你录音了吧,要不然不可能记得住那么多。

真是 CS 学成文科了
geekaven
2021-02-08 01:13:15 +08:00
普通小厂也是这样吗?有点吓人
Jooooooooo
2021-02-08 01:14:46 +08:00
第一大段给楼主筛选下稍微有价值的题目, 如果不知道答案最好搜一搜

1. 讲下 hashmap 的扩容机制, 为什么要转红黑树?
2. 为什么 hashmap 会造成死循环?
3. ConcurrentHashMap 是怎么做到线程安全的?
4. volatile 的功能?
5. Happened-before 是什么?
6. CAS 是什么?
7. 说下 AQS 的原理?
8. java 中的线程怎么对应到操作系统上?
9. 具体的业务线程池的参数会考虑哪些因素?
10. NIO 的优势具体体现在哪?

(真要讲一句, 就算整理过这些题目质量也够低的. 可能真正有价值的是第九题. 没真的搞过的人一般答不好, 算是一个符合 star 原则的题目
young1lin
2021-02-08 01:33:43 +08:00
@shmilypeter 面多了,习惯了
young1lin
2021-02-08 01:34:00 +08:00
@geekaven 小厂应该抽几道题目吧
young1lin
2021-02-08 01:36:52 +08:00
@Jooooooooo 放心,都会问的,尤其是大厂,或者是大厂出来创业的人。上来给我八股文过招,哼,不过如此。线程池必问。NIO 、AIO 、BIO 必问,放心,会问到你不会为止。

这些只是最基本的,还有更多的内容在我的 Github 上面的,还有问我异常处理如何做的?我讲了 《 Effective Java 》的做法,以及 Spring 的 nested Exception 那种做法。
young1lin
2021-02-08 01:38:40 +08:00
@drackzy 就是这么卷,Java 是最卷的语言,这个不过分吧?
lewis89
2021-02-08 03:51:48 +08:00
@Jooooooooo #50

具体考虑哪些参数? 除开那个 stealworking 的线程池

其余的线程池只能设置核心线程数 跟 Queue 的具体实现 以及最大线程池数?

设置的话,一般都是按经验来,然后最好是有线程池监控,美团也是这么做的?

而且也要看是 IO 密集型还是计算密集型,计算密集型 妥妥的跟核心数量一致就行了 频繁的切换没有必要,也浪费 CPU 时间?

如果 IO 密集型,没得说,把下游的 硬盘 网络 IO 往死里搞,打满 80%为止..?
lewis89
2021-02-08 03:54:19 +08:00
@liprais #9

如果只是说概念的话,ACID 倒还是好说 ,要说实现细节,光是 MySQL 引擎实现 C 的细节, 刷写脏页 以及 undolog 的格式 细节上来 可以问上半天.. 然后顺带问下 binlog 格式 以及主从同步..

没办法就是这么卷
lewis89
2021-02-08 03:57:35 +08:00
@hehe12980 #10 可能面试官想了解你对 GC 算法的理解吧,其实就我而言,我也不会去背那些参数,因为大部分能调的几个参数无非是在吞吐量跟停顿时间 取得一个平衡,想要高吞吐量 那么就只能牺牲停顿时间,反之也是如此..

包括 G1 的 XX:MaxGCPauseMillis 意义不大,你调低了,自然吞吐量上不去,调高了停顿时间就会多,这个还是要根据你线上的 JVM 实例的真实情况 来做决定
ConradG
2021-02-08 04:44:38 +08:00
我比较在意那个 O(1)链表有环的算法。
ming7435
2021-02-08 08:30:04 +08:00
这尼玛真的是吓人,工作 10 年+的人不敢出去面试,因为不会背八股文
liupeng2579793
2021-02-08 10:16:10 +08:00
五分之一都没啊,好兄弟

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/752020

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX