各大互联网公司面经分享:Java 全栈知识 +1500 道大厂面试真题

news2024/11/14 15:12:46

这篇文章给大家分享一下我遇到的一些质量较高的面试经历,具体经过就不多说了,就把面试题打出来供各位读者老哥参考如有不全的地方,各位海涵。

猿辅导

  1. 八皇后问题

  2. 求二叉树的最长距离(任意两个节点的路径 中最长的)

  3. lru 算法的实现

  4. 设计一个数据结构 满足 put 和 getMedium(中位数)两个方法. (时间复杂度分析, getMedium 在常数,n,log n 时间复杂度返回如何实现)

  5. rabbitmq 脑裂问题,rabbitmq 延迟队列实现, rabbitmq 高可用策略(因为项目中用到了 rabbitmq 他们技术选型出现了重叠,问了这个问题)

  6. 死磕项目细节:其中包括: 设计方案时有没有比较多种方案,为什么选这个方案?你个人最有成就感,最有挑战性的 工作是哪一个?

去哪儿

  1. 为什么使用 MQ, MQ 如何选型, 消息可靠性如何保证, 如何保证幂等

  2. 用过 dubbo 吗? 设计一个 rpc 框架

  3. 介绍一下 https

  4. 数据库线程池, http 连接池有没有深入看过源码?介绍一下.(项目里用得到了 http client)

  5. 给你十亿条数据,如何最快的添加到数据库中

  6. 分布式锁的技术选型, 实现原理, 优劣势比较, zookeeper 的一致性协议原理

  7. java 线程同步的几种方式, countdownlatch 和 栅栏的区别

  8. synchronized 和 aqs 如何实现可重入锁陌陌

  9. 分布式锁的实现方案比较,为什么选择 zookeeper, zookeeper 一致性协议原理

  10. 一致性 Hash 原理,实现,项目中是如何使用一致性 Hash 的,引入了多少虚拟节点?

  11. java synchronized 和 AQS 的原理,区别

  12. redis 有序列表

  13. redis 高可用架构是什么? codis 和 redis cluster 分片的区别

  14. 两个线程如何交替打印 0 到 99

头条(Go)

  1. top-k

  2. 实现前缀树

  3. 实现 python 装饰器.方法实现,和类实现, 带参数和不带参数.以及对装饰器的思考

  4. 如何实现对 多机房,多机架 之前的网络健康情况监控

  5. 如何理解进程上下文切换, 进程地址空间,为什么需要进程地址空间, 系统调用实现原理, top 命令介绍.

阿里

  1. mq 消息可靠性,幂等如何保证

  2. 分布式锁的实现方案比较,为什么选择 zookeeper, zookeeper 一致性协议原理

  3. 线程池参数,阻塞队列实现.

  4. 一致性 Hash 解决什么问题, 如何实现? 虚拟节点的作用?

  5. Java 锁的实现方式, 比较? AQS 实现原理?公平非公平实现原理?

  6. CAS 实现原理

  7. volatile 实现原理, 单例模式

  8. java 内存模型, gc 调优的经历. cms gc 的几个阶段, 为什么会出现 stop the world. 常见可优化参数有哪些.

  9. 为什么需要优化 gc, gc 会导致什么问题

  10. mysql 事务隔离级别. mvcc 实现原理

  11. mysql 索引原理. 为什么使用 B+树. 及何时无法使用索引?

  12. mysql 架构, 引擎层和 server 层 各自负责什么.

  13. hashmap 及 concurrenthashmap 实现原理

  14. Spring aop 原理,如何定义新的 spring xml 标签

  15. 合并两个有序链表

  16. 如何设计一个 大型活动的安保系统(开放题)

  17. 你平常都在哪些论坛上学习?

  18. 如何学习一门未知的技术?思考:阿里面试官 虽然不面算法,但是面试考察点全方位打击,从浅入深,揪住不放,直到你不会为止.是收获最多的面试,也是感受到自己差距的面试.

快手

  1. 线程池实现原理,如何调优

  2. 如何实现一个延迟队列

  3. mysql 索引

  4. mysql 事务隔离级别

  5. java 锁和常见线程同步方式

  6. zookeeper 分布式实现方式及优劣,如何避免 多个客户端同时获取到锁?

  7. 求二叉树两个节点的共同节点

  8. 求二叉树的深度(非递归)

  9. java 集合常见类及原理

  10. tcc 原理

  11. netty 的请求处理流程.线程模型

美团

1. HashMap 的实现原理?扩容原理? 为什么 jdk 8 修改了冲突链表的插入位置

2. mysql 的高可用架构.主从同步过程.

3. http 和 rpc 调用的区别

4. redis 如何用单线程支撑高并发, redis 的常见使用场景

5. mq 如何选型为什么用 mq

6. 一致性 Hash 原理

7. 美团外卖的支付 ,要求在 15 分钟内取消未支付的订单. 如何实现

8. 打印 * 星号的等腰三角形

9. 项目的全链路架构, 有没有单点问题,解决单点问题有哪些常见的方案

10. 项目中有哪些可以衡量工作产出的指标.

11. 说一下你负责的 最复杂,参与人数最多,周期最长的项目是如何推进的

12. 你认为自己的优势,劣势在哪里

13. 你对未来的职业规划,你期望的工作内容,方向是什么?

腾讯(Java)1.如何在物理机和容器中获取 cpu 核数,如何设置线程数, 如何主动触发 GC

2.一致性 Hash, Hash 的作用, 为什么叫一致性 Hash,一致性体现在哪里. HashMap 中还可以使用什么方式处理 Hash 冲突

3.线程池参数,优化,原理

4.实现一个功能:cat /usr/local/*.log|grep tencent

5. 如何理解 Future 模式?java 的实现原理

6. Java 阻塞队列实现原理

7. java 锁 volatile 实现原理

8. mysql 索引原理,事务隔离级别, mysql 死锁的场景会有哪些, 内部如何检测死锁的?

9. java 线程同步共有哪几种工具?

10. 你认为 java 设计得比较优秀的地方有哪些?

11. 如何理解面向对象设计,能用你看过的开源代码或者实际项目介绍一下吗?

12. java 类加载器的原理及实际使用场景

13. java 内存模型, 虚拟机栈默认大小

14. 说一下高可用架构的常见解决思路

思考

1. 手撕算法需要准备,面试之前保证刷够 100 题,及部分设计题.

2. 无论会不会,一定不能慌.无论会不会,一定要和面试官确认自己的理解是不是正确,这道题应该如何思考? 避免跑偏

3. 面试重点在于沟通.

3.1 强行总结结论

一定要有条理性的和面试官沟通. 避免东一扫帚,西一扫帚.最好提前想好一些结论,重复几遍.这样面试官可能直接用你的"结论"来 写面试经过,结论,评价等. 说完一件事,最好有条理性的结论,让面试官印象深刻. 即使强行 1,2,3 的划重点结论也比戛然而止强.

3.2 优雅的中断当前问题,只在检查点退出讨论,响应面试官的中

当面试官出现了疑问,抛出了问题,中断你的回答,一定不要一味的回答,立即响应,把握自己的节奏,向面试官征求意见,能否把剩下的说完.继续快速的说完,记得总结结论求同存异,避免争论。

面试三千问

简历重要吗? 随便写行不行

简历一定要认真写.面试官抛出的问题中,除了常见的高频面试题,就是简历中你写的东西.要保证简历中写的东西,透彻理解! 无论写的是了解,还是精通都要精通. 否则别写我认为不用写的 1.不熟悉的,仅仅是知晓的.2.在学校整的东西,没啥知名度就不要写了 3.github 要有,但是我没有被问过 github 中的项目

项目经历问吗?

项目经历一般是 面试必问的,重点问的. 所以第一步要优先发掘自己项目中的亮点, 把自己做的工作清晰的写出来.自我介绍阶段重点介绍应该也是自己的项目经历,这时最好自己提前准备一份演讲稿把自己的项目亮点说出来.多练几遍.避免不过脑子,黄河决堤式回答,想到哪里说哪里.

常见高频问题呢?

java 锁,线程同步,Juc 包.线程池内存模型,gc 调优 mysql 索引,锁,事务隔离级别.常见分布式高可用架构 redis, mysql, zk, mq 等. 数据同步,数据分片,数据备份等

需要刷题吗?

阿里一般不会问太多算法题.但是至少一半以上公司都会手撕算法. 把 leetcode 各个类型的题都刷十道以上基本没太大问题. hard 题一般不会问.如果自己面试表现非常好,但是因为算法题被刷掉是不是会很遗憾呢?算法题能扩展一个人的思路,还是有用的.也锻炼一个人编码能力. 个人建议白板算法用 python 非常简洁.更聚焦解题思路

如果自己面试表现特别好,职位匹配度非常高. 算法题是可以防水的,会挑简单题问. 目的就是 留下你,怕你答不上来,避免尴尬

但是自己面试比较差, 算法题答得特别好,会不会扭转面试结果呢? 基本不会, 手撕算法只是辅助.项目经历和基础面试题是核心.

面试结果可以问吗?

如果没有面试到 hr,或者 终面面试官没有明确 hr 会联系,我基本都会问. 或者问一下自己的不足. 一般都会告诉自己.另外, 手撕算法 OK,也会被刷掉. 我在陌陌就是 手撕算法非常完美,结果还是挂了.

一般几轮面试?

不算 hr ,基本都是三轮及以上. 但如果二轮面试官开始扯虚的,和你介绍项目,问你职业规划 也许二面就是终面. 不清楚就问一下面试官.

平时工作划水, 面试临时抱佛脚行不行?

不幸当面试官逼问项目细节时, 如果平时没有对细节特别熟悉,做事马马虎虎,技术深度不够,例如技术选型为什么这么做,其他方案?优劣势是什么?如果没有调研,面试时,很快会露出马脚.如果对项目的整体架构不熟悉,只熟悉自己的模块,也会可能被面试官问到关联的模块,项目如果自己不熟悉,马上就会支支吾吾.如果你回答,这块不是我负责的,我不太熟悉,就会让面试官对你产生 没有大局观,主动意识不够的狐疑.评价时会被评"只能完成自己模块内的工作,对系统的全局没有了解,主动意识不强.自我驱动意识差"工作时,可能仅仅聚焦业务,对于项目中应用的技术关注不足. 面试时候就会被面试官揪住.如果当时不思考清晰,并且面试前没有意识到这块技术风险, 就会给面试带来很大风险.美团面试官曾问我,介绍一个你主要负责的 参与方最多,周期最长,最复杂的一个项目如何推进的? 如果平时工作不积极,不主动思考,面试被摊上这么一个问题.基本上哑口无言. (我就目瞪口呆了)

仅仅看博客,把高频面试题搞懂行不行? (问题驱动式准备面试)

这是必须要做的事情.但是仅仅做到这些还远远不够例如:阿里面试官问:gc 为什么一定要 stop the world? 一般博客没有给出明确清晰直观的原因

一致性 Hash 如何实现? 手撕一下.为什么叫一致性 hash,一致性体现在哪里? 一般博客没有 lru 算法手撕一下. 博客有,看一遍就能手撕了?

redis 和 zk 分布式锁实现如何选型? 各自缺点,优势?项目使用时如何避免缺点带来的负面影响?

如何基于 AQS 实现获取锁的公平性非公平性?

面试官甚至给你埋坑,故意说一个错误的,看你能否反驳

我之前被带坑过, 线程池问题 面试官问:是先到 max size 还是先添加到阻塞队列?我说 阻塞队列满了才会继续创建线程到 max size 面试官: 是这样吗? 那么如果是无界队列岂不是永远无法到达 max size 我心想: 是啊,有道理,我可能记错了.然后被面试官带偏了

所以结论是,光看懂记下来,不够,要深刻理解.时刻带着问题去学习.问题驱动式学习

最后你会发现,过了许久,你印象最深刻的还是自己当初提出来的疑问及其解决思路和答案

最后更新一下面试结果吧:

腾讯: 加班太多,部门一般, 再加上时间不充裕 放弃后续面试

去哪儿:23K

快手:一面挂了

陌陌: 二面挂

头条: 25k (据说 15 薪)

美团: 25k 给不起(说面试过了, 要了期望薪资,没了下文. 现在美团离职人超多, 招人薪资压得很低)

蚂蚁金服:hc 收缩 发不出 offer, 据面试官承诺可以给到 28k+.(蚂蚁 p6 是基本没有议价权,所以直接告诉大概薪资. 但是没有纸质 offer 可信度也不是特别高)

猿辅导: 25-30k 之间 (据说 14 薪, 入职了这家, 具体不透露了, 反正毕业两年的人绝大部分在这个区间里)

最后权衡了一下 , 不太想玩命加班. 去了猿辅导. 这些薪资基本上也算是市场平均价吧

猿辅导的福利基本上和宣传的出入不大.但是项目紧急还是需要加班,不过这点强度算是一个上升期互联网公司的最后底线吧

对于面试,刷面试题固然重要,但是我觉得理解核心的知识点更重要,下面这份大牛整理出来的 Java 全栈知识点可以说囊括了当前最热门的一些技术,可供大家参考

JVM

  • 线程

  • JVM 内存区域

  • JVM 运行时内存

  • 垃圾回收与算法

  • JAVA 四中引|用类型

  • GC 分代收集算法 VS 分区收集算法

  • GC 垃圾收集器

  • JAVA IO/NIO

  • JVM 类加载机制

Java 集合

  • 接口继承关系和实现

  • List

  • Set

  • Map

  • JAVA 多线程并发

  • JAVA 并发知识库

  • JAVA 线程实现/创建方式

  • 4 种线程池

  • 线程生命周期(状态)

  • 终止线程 4 种方式

  • sleep 与 wait 区别

  • start 与 run 区别

  • JAVA 后台线程

  • JAVA 锁

  • 线程基本方法

  • 线程上下文切换

  • 同步锁与死锁

  • 线程池原理

  • JAVA 阻塞队列原理

  • Clicarrier. CountDownLatch. Semaphore 的用法

  • volatile 关键字的作用(变量可见性、禁止重排序)

  • 如何在两个线程之间共享数据

  • ThreadLocal 作用(线程本地存储)

  • synchronized 和 ReentrantL ock 的区别

  • ConcurrentHashMap 并发

  • Java 中用到的线程调度

  • 进程调度算法

  • 什么是 CAS (比较并交换乐观锁机制锁自旋)

  • 什么是 AQS (抽象的队列同步器)

Spring 原理

  • Spring 特点

  • Spring 核心组件

  • Spring 常用模块

  • Spring 主要包

  • Spring 常用注解

  • Spring 第三方结合

  • Spring 10C 原理

  • Spring APO 原理

  • Spring MVC 原理

  • Spring Boot 原理

  • JPA 原理

  • Mybatis 缓存

  • Tomcat 架构

微服务

  • 服务注册发现

  • API 网关

  • 配置中心

  • 事件调度(kafka)

  • 服务跟踪(starter-sleuth)

  • 服务熔断(Hystrix)

  • API 管理

Netty 与 RPC

  • Netty 原理

  • Netty 高性能

  • Netty RPC 实现

  • RMI 实现方式

  • Protoclol Buffer

  • Thrift

网络

  • 网络 7 层架构

  • TCP/IP 原理

  • TCP 三次握手/四次挥手

  • HTTP 原理

  • CDN 原理

RabbitMQ

  • 概念

  • RabbitMQ 架构

  • Exchange 类型

设计模式

  • 设计原则

  • 工厂方法模式

  • 抽象工厂模式

  • 单例模式

  • 建造者模式

  • 原型模式

  • 适配器模式

  • 装饰器模式

  • 代理模式

  • 外观模式

  • 桥接模式

  • 组合模式

  • 享元模式

  • 策略模式

  • 模板方法模式

  • 观察者模式

  • 迭代子模式

  • 责任链模式

  • 命令模式

  • 备忘录模式

  • 状态模式

  • 访问者模式

  • 中介者模式

  • 解释器模式

负载均衡

  • 四层负载均衡 vs 七层负载均衡

  • 负载均衡算法/策略

  • LVS

  • Keepalive

  • Nginx 反向代理负载均衡

  • HAProxy

数据库

  • 存储引擎

  • 索引

  • 数据库三范式

  • 数据库是事务

  • 存储过程(特定功能的 SQL 语句集)

  • 触发器(一段能自动执行的程序)

  • 数据库并发策略

  • 数据库锁

  • 基于 Redis 分布式锁

  • 分区分表

  • 两阶段提交协议

  • 三阶段提交协议

  • 柔性事务

  • CAP

分布式缓存

  • 缓存雪崩

  • 缓存穿透

  • 缓存预热

  • 缓存更新

  • 缓存降级

一致性算法

  • Paxos

  • Zab

  • Raft

  • NWR

  • Gossip

  • 一致性 Hash

JAVA 算法

  • 二分查找

  • 冒泡排序算法

  • 插入排序算法

  • 快速排序算法

  • 希尔排序算法

  • 归并排序算法

  • 桶排序算法

  • 基数排序算法

  • 剪枝算法

  • 回溯算法

  • 最短路径算法

  • 最大子数组算法

  • 最长公共子序算法

  • 最小生成树算法

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/815506.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

第二季度财报超预期,利润率大幅提高,Meta股价将进一步上涨

来源:猛兽财经 作者:猛兽财经 总结: (1)Meta(META)公布了强劲的第二季度财报,超出市场预期,利润率也大幅提高,导致其股价上涨了5%。 (2&#xf…

“程序员求职攻略:IT技术岗面试的必备技巧“

文章目录 每日一句正能量前言分享面试IT公司的小技巧IT技术面试有哪些常见的问题?分享总结遇到过的面试题后记 每日一句正能量 人活一世,不在乎朋友多少,不问财富几车,关键看在你最困难的时候,是否有一个伸出援手的人&…

URP基于GL的Unity物体网格线绘制方法参考

直接上代码: using System; using System.Collections.Generic; using UnityEngine; using UnityEngine.Rendering;public class GLWireMesh : MonoBehaviour {[Serializable]public class IntPair{public int a;public int b;public IntPair(int a, int b){this.a…

jenkins自定义邮件发送人姓名

jenkins发送邮件的时候发送人姓名默认的&#xff0c;如果要自定义发件人姓名&#xff0c;只需要修改如下信息即可&#xff1a; 系统管理-system-Jenkins Location下的系统管理员邮件地址 格式为&#xff1a;自定义姓名<邮件地址>

洞悉安全现状,建设网络安全防护新体系

一、“网络攻防演练行动“介绍 国家在2016年发布《网络安全法》&#xff0c;出台网络安全攻防演练相关规定&#xff1a;关键信息基础设施的运营者应“制定网络安全事件应急预案&#xff0c;并定期进行演练”。同年“实战化网络攻防演练行动”成为惯例。由公安部牵头&#xff0…

【2023年11月第四版教材】《第1章-信息化发展之<1信息与信息化>》

第01章-信息化发展 1 信息与信息化 大部分为新增内容&#xff0c;预计选择题考4分&#xff0c;案例和论文不考。本章与第三版相同内容将斜体表示。 1 信息与信息化 1、信息是物质、能量及其属性的标示的集合&#xff0c;是确定性的增加。 2、控制论的创始人维纳认为:信息就是信…

easyui主表子表维护页面

easyui主表子表维护页面 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><title>Title</title><!-- <#include "common.html"/> --><link rel"stylesheet" type&quo…

win10浏览器无法选择双面打印解决方案

win10浏览器无法选择双面打印解决方案 应用场景&#xff1a;当我打开wps设置双面打印某个pdf文件时&#xff0c;屏幕提示我要手动翻页进行双面打印&#xff1f;&#xff01;&#xff01;&#xff01;什么情况。那就使用浏览器打开pdf文件进行打印吧&#xff0c;但是竟然没有双…

兼容性在APP开发中的重要性:一个不可忽视的因素

APP开发过程中&#xff0c;有许多因素需要考虑。其中一个是兼容性。如果 APP无法运行&#xff0c;用户将无法使用它&#xff0c;或者他们无法完成自己的工作。这对用户和公司来说都是非常令人沮丧的。 许多 APP开发公司都有能力解决兼容性问题。然而&#xff0c;一些公司甚至没…

SAP abap sql 语句执行无结果

有些情况下&#xff0c;我们的sql语句执行之后&#xff0c;却没有得到结果&#xff0c;可能是因为条件不对 原因是SAP 中se16n看见的值可能经过转换&#xff0c;例如下面的SQL&#xff0c;就会执行失败&#xff0c;因为SH 实际上是WE转换过来的&#xff0c;这时候我们需要点开详…

C++继承特性(4)——友元与静态

目录 一.继承与友元的关系 二.继承与静态成员的关系 先回顾一下静态成员变量&#xff1a; 运行TestPerson()函数&#xff1a; 测试案例2&#xff1a; 三.练习题&#xff1a; 一.继承与友元的关系 友元关系不能被继承&#xff0c;也就是说父类中的友元函数不能访问子类私…

IT职场笔记

MySQL笔记之一致性视图与MVCC实现 一致性读视图是InnoDB在实现MVCC用到的虚拟结构&#xff0c;用于读提交&#xff08;RC&#xff09;和可重复度&#xff08;RR&#xff09;隔离级别的实现。 一致性视图没有物理结构&#xff0c;主要是在事务执行期间用来定义该事物可以看到什…

Python爬虫+数据可视化:分析唯品会泳衣数据详情

前言 嗨喽&#xff0c;大家好呀~这里是爱看美女的茜茜呐 唯品会是中国领先的在线特卖会电商平台之一&#xff0c;它以“品牌特卖会”的模式运营&#xff0c;为会员提供品牌折扣商品。 唯品会的商品包括服装、鞋类、箱包、美妆、家居、母婴、食品等各类品牌产品。 这就是今天…

RFID在半导体行业的应用解决方案

半导体行业近几年来受到疫情因素和政治因素的影响&#xff0c;导致国内芯片的短缺问题十分严重&#xff0c;在国家大力发展制造企业的趋势下&#xff0c;不少企业也加大了芯片制造工厂的投入。RFID作为一种可非接触识别的技术&#xff0c;是如何应用在半导体行业中的?下面我们…

JsonPath使用和示例

JsonPath使用和示例 1 简介2 官方实例3 JsonPath与XPath语法对比4 实例说明JsonPath与XPath语法5 Python中JsonPath模块6 Python中JsonPath使用7 结合接口测试的实例 1 简介 官网&#xff1a;https://goessner.net/articles/JsonPath/&#xff1b;JsonPath 是一种简单的方法来…

做了5年软件测试决定离职,跳槽历经40场面试, 面的基本都是大厂

前言 沉寂了好一段日子&#xff0c;连我们公司自己人都问我为什么最近都不写文章了。 那么当看到本篇的标题的时候&#xff0c;大家应该可以猜到这是为什么了。 我最终还是决定要离开服务了 5 年多的公司。 而这次跳槽历经 3 个月&#xff0c;前后聊了 10 家公司&#xff0c;进…

问题:idea启动项目错误提示【command line is too long. shorten command line】

问题&#xff1a;idea启动项目错误提示【command line is too long. shorten command line】 参考博客 问题描述 启动参数过长&#xff0c;启动项目&#xff0c;错误提示 原因分析 出现此问题的直接原因是&#xff1a;IDEA集成开发环境运行你的“源码”的时候&#xff08…

Spring学习笔记之入门程序

文章目录 关于下载介绍jar包第一个入门程序关于入门程序的小细节启用Log4j2 关于下载 这是一个悲惨而又戏剧性的故事 其实是不用下的&#xff0c;spring的jar包是归meaven管的&#xff0c;不用特地的去spring官网再去什么github上下载&#xff0c;再去看什么乱七八糟的目录&a…

IDEA的基础使用——【初识IDEA】

IDEA的基础使用——【初识IDEA】 文章目录 IDEA简介前言官网 IDEA的下载与安装选择下载路径勾选自己需要的其余按默认选项进行即可 目录简介安装目录简介 运行Hello WorldIDEA快捷键常用模板模板一&#xff1a;psvm&#xff08;main&#xff09;模板二&#xff1a;模板三&#…

adb常用命令使用

1.查看当前运行的包名和Activity adb shell dumpsys window | findstr mCurrentFocus 2.卸载app adb uninstall io.appium.settings adb uninstall io.appium.unlock adb uninstall io.appium.android.ime