Java 编程入门经典,慕课网 java 架构师百度网盘,字节跳动 Java 高级工程师
美团一面:
中间省略掉大概几个问题,因为我不记得了,下面记得的基本都是我没怎么答好的。
了解 SOA,微服务吗?
分布式系统如何负载均衡?如何确定访问的资源在哪个服务器上?
一.轮询。二.随机。三.最小响应时间。四. 最小并发数。五.哈希。
设计一个分布式负载均衡缓冲系统,如何快速定位到是那个服务器(使用 key 分段、一致性 hash)
如何保证缓冲区和数据库之间的强一致性(使用加锁)
HashMap 高并发情况下会出现什么问题,(扩容问题)
说一说在浏览器中输入一个 url 后,直到浏览器显示页面的过程中发生了什么(我主要说了 DNS,然后他有接着问了 DNS 的细节,然后就是 ARP 路由,然后服务器处理,返回,浏览器呈现,获取 html 中的依赖资源)
字符串中句子的反转(比如 ABC DEF,输出 DEF ABC)(很简单,可以先反转整个字符串,然后反转单词,或者先将句子切分为单词,然后反转);
给任意二叉树的所有结点加 next 指针(这个有原题,也可以参考按层打印二叉树)。
用过反向代理吗?
美团二面:
进程间共享内存的方式有哪些?(8 种)
linux 下如何查看网络端口状态(netstat),如何查看内存使用情况(top)?
ConcurrentHashMap 如何扩容?
知道 java 的异常吗?
运行时异常如果不处理会怎么样?应该怎么处理运行时异常?
写代码:给你 5000 万个 int,求出前 1000 个最大的数,有 2G 内存。(我刚开始以为 5000 万个 int 很多,还把 G 和 byte 的换算忘了,后来面试官指导才想起来。我的方法是维护一个 1000 的小根堆,然后遍历数组,总体下来时间复杂度是 O(nlg1000))
给你 n 个不重复的整数,随机找出 m 个不重复的整数,要求时间和空间复杂度都是 O(m)。(方法很简单,就是每次把取出来的数放到后面,只在前面的数组随机访问就可以了,时间复杂度是 O(m),空间复杂度是 O(1),不过我刚开始没有想到把选出来的放后面去)。
对于 SQL 慢查询的优化?(主要是从查询语句和数据库表设计两个方面来考虑,查询语句方面可以增加索引,增加查询筛选的限制条件;数据库表设计的时候可以拆分表,设计得更细粒度。但是后来才发现面试官想要的就是查询大量数据的慢查询问题的优化。)
用过哪些容器?(tomcat)对比过 Tomcat 与其他服务器的区别吗?比如 nginx?
用过动态代理吗?以后会经常用到的。
美团三面:
自我介绍,说说你项目中的数据流向(画结构框图)
看过什么书?
说说深入理解 JVM 中印象最深刻的章节(我说了 JVM 内存模型,垃圾回收和类加载);
补充:还问了堆和栈中存的是什么?static 修饰的遍历存在哪里?(方法区)
说说《Effective Java》中你印象最深的三条和你的理解
你觉得你哪一块只是最熟悉(我说了 Java 的基本数据结构)
那你说说 HashMap 的内部实现;
HashMap 是线程安全的吗?(不是,ConcurrentHashMap 是)
那 ConcurrentHashMap 内部是如何实现的?每个 segment 是个什么数据结构?(HashTable)
你的项目中用到哪些技术?(Spring)
说说你用了它的什么?(Spring IOC 用的最多)
Spring 的优点?Spring AOP 的原理?Spring 如何实现解耦合?
对链表了解吗?(我说是 List 吗)是,(了解 ArrayList 和 LinkedList),那你说说他们的区别?
会做链表两个结点的交换吗?(链表反转吗?)是的,你写代码实现把。
再写一个,给你一个链表和一个整数 k(k 大于等于 0,小于等于链表长度,链表长度未知),按 k 步
反转链表(比如 1->2->3->4->5->6->7,当 k=3 的时候结果是 3->2->1->6->5->4->7)
说说 mybatis 配置了 xml 过后是如何完成数据库操作的?
最后
我还为大家准备了一套体系化的架构师学习资料包以及 BAT 面试资料,供大家参考及学习
已经将知识体系整理好(源码,笔记,PPT,学习视频)
评论