2021金九银十面试季!java使用父类方法

本文详述了在美团、字节跳动和腾讯面试中遇到的高难度技术问题,涵盖MySQL、Redis、Kafka、线程、算法、设计模式等多个方面。面试官深入探讨了数据库优化、分布式系统、并发编程以及算法实现,揭示了企业对程序员深厚的技术要求。同时,文章指出,随着行业门槛提高,自学需谨慎,建议考虑线上教育,因其价格适中、资源丰富、时间灵活且课程深入。
摘要由CSDN通过智能技术生成

第一家是美团

美团的话,三面下来,设计的内容知识也是挺广的吧,有MySQL、Redis、Kafka、线程、算法、+、volatile、线程、并发、设计模式等等…
image.png

一面问题:MySQL+Redis+Kafka+线程+算法

  • mysql知道哪些存储引擎,它们的区别

  • mysql索引在什么情况下会失效

  • mysql在项目中的优化场景,慢查询解决等

  • mysql有什么索引,索引模型是什么

  • B-树与B+树的区别?为什么不用红黑树

  • mysql主从同步怎么做

  • 乐观锁与悲观锁的区别?

  • binlog日志

  • redis 持久化有哪几种方式,怎么选?

  • redis 主从同步是怎样的过程?

  • redis 的 zset 怎么实现的?

  • redis key 的过期策略

  • hashmap 是怎样实现的?为什么要用红黑树,而不用平衡二叉树?为什么在1.8中链表大于8时会转红黑树?HashMap为什么线程不安全的?

  • 如何实现线程安全的hashmap?

  • select 和 epoll的区别

  • http与https的区别,加密怎么加的?

  • raft算法详细讲解

  • Kafka 选主怎么做的?

  • kafka如何保证生产与消费都是同步的?

  • kafka 怎么保证不丢消息的

  • redis如何保证高可用

  • 算法:剪绳子(贪心或递归解决)

  • 算法:给前序和中序遍历,重建二叉树

二面问题:volatile+线程+并发+算法+设计模式

  • 自我介绍

  • 讲讲项目(项目没啥亮点,直接问基础)

  • volatile作用?底层实现?禁止重排序的场景?单例模式中volatile的作用?

  • 如何构造线程池,它的参数,饱和策略?

  • 公平锁和非公平锁区别?为什么公平锁效率低?

  • 线程都有哪些状态?

  • 线程、进程、协程的区别?

  • 同步队列器AQS思想,以及基于AQS实现的lock,。

  • 并发工具类CountDownLatch、CyclicBarrier、Semaphore介绍

  • Execuors类实现的几种线程池类型,最后如何返回?

  • 手写单例模式

  • 手写消费者生产者模式

  • 算法:反转单链表

  • 算法:给定一个只包含 ‘(’ 和 ‘)’ 的字符串,找出最长的包含有效括号的子串的长度。

三面

这一面,没问啥东西,主要聊人生,和未来3年的规划。。。。。。

第二家是字节跳动

image.png

一面问题:算法+数据库+事务+网络

  • 自我介绍

  • 项目介绍(没亮点,还是问基础)

  • 堆排序的原理及时间复杂度,是否稳定,最坏及最坏场景。

  • Object类都有哪些方法?

  • DNS解析的过程/浏览器输入一个url,敲下回车后网络的全过程

  • HTTP和HTTPS的区别

  • UDP怎么实现可靠传输

  • 介绍下https,是如何加密的,加密算法

  • 数据库索引的优缺点,以及什么时候数据库索引失效

  • 事务的隔离级别?

  • 数据库的脏读,不可重复读,幻读

  • 算法:接雨水:给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。

  • 算法:N皇后

二面问题:Kafka+redis+算法

  • Kafka的特性?

  • Kafka中的分区器、序列化器、拦截器是否了解?它们之间的处理顺序是什么?

  • 消费者重平衡(高可用性、伸缩性)

  • 哪些情景下会造成消息漏消费?

  • 如何保证消息不被重复消费(幂等性)

  • KafkaConsumer是非线程安全的,那么怎么样实现多线程消费?

  • Kafka生产者客户端中使用了几个线程来处理?分别是什么?

  • 消费者与生产者的工作流程:

  • topic的分区数可不可以增加?

  • 算法:二叉树中的最大路径和

  • 算法:给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。

三面问题:Redis+Spring+Dubbo+算法

  • redis的Zset怎么实现的?

  • sentinel和cluster区别和各自适用场景

  • redis cluster集群同步过程

  • redis单线程为什么快?

  • mybatis一级缓存和二级缓存

  • spring如何解决循环依赖?

  • spring AOP的原理。

  • spring的生命周期。

  • Dubbo服务暴露和引用过程,负载均衡策略,容错机制在哪里实现的源码

  • 项目中遇到了哪些问题。(抱歉,我的工作就是增删改查,没接触过相关问题)

  • 算法:二叉树的镜像

  • 算法:从上到下打印二叉树

最后一家,瞄一下腾讯

腾讯这三面下来问的也不少,自求多福吧。

image.png

一面问题:高并发+微服务+算法

  • 如何设计一个秒杀系统?

  • 一天爬一千万条文章,怎么做设计?怎么并行协调?100 台服务器怎么尽可能负载均衡?

  • 有用过短域名服务吗,能说一下吗?

  • 微服务的特点,如何实现服务发现和负载均衡

  • 如何排查线上问题?(背过,没排过)

  • 贝叶斯的概率学原理

  • 负载均衡的加权轮询算法怎么实现

  • 如果用户量大幅度上涨,如何优化?

  • paxos算法(这个算法太难,学的时候就没太理解)

  • 平时都看什么博客,最近看什么书了

二面问题:Redis+分布式+算法

  • 自我介绍

  • 项目介绍

  • redis的5种类型,及其实现原理

  • 如何使用redis的Zset实现延时队列?

  • redis如何实现高可用?

  • redis缓存穿透、缓存击穿、缓存雪崩

  • 布隆过滤器的实现

  • 如何保证mysql与redis的双写一致性?

  • 负载均衡算法有哪些?

  • 服务发现是怎么实现的?

  • 熔断是怎么实现的?

  • 算法:连续子数组的最大和

  • 讲讲分布式CAP和BASE?

  • 什么是强一致性?

  • 分布式事务的解决方案?

  • TCC(两阶段型、补偿型)

  • id生成器如何实现?

  • 如何判断一个图是否有环?

  • 一致性Hash算法,及其应用

  • 背包问题

三面问题:Redis+分布式+MySQL+算法

  • 自我介绍

  • 项目介绍

  • redis的zSet如何实现?

  • redis持久化机制。

  • redis的Hash类型讲解,渐进式rehash。

  • HashMap原理,一个put操作,都有什么流程?

  • nginx有自己配置过吗(这个是我唯一手动操作过的,这个不是背的)

  • nginx的使用场景。

  • 什么是分布式,什么是集群,区别是什么?

  • 在基于dubbo的分布式环境中,一般将超时timeout设置在provider还是consumer?

  • dubbo中负载均衡的策略有哪些?

  • 接口的异步调用?如何设置?运行效果?

  • 谈谈基于dubbo的系统中consumer集群的解决方案?

  • mysql是集群还是单节点?最大连接数,最大的表中数据量大约是多少?

  • mysql主从复制主要有哪几种模式?

  • mysql索引,B+树,为什么不用红黑树?

  • 数据库垂直与水平拆分怎么做。

  • 分布式session设置

  • IO、BIO、NIO,阻塞与非阻塞的区别?

  • 分布式接口的幂等性设计(不能重复扣付款)

  • 算法:二叉搜索数与双向链表(这个懵了)

  • 算法:最长不含重复字符的子字符串

  • 算法:手写快速排序、插入排序、冒泡排序,并分析时间复杂度和空间复杂度,它们的稳定性

最后

为什么我不完全主张自学?
平台上的大牛基本上都有很多年的工作经验了,你有没有想过之前行业的门槛是什么样的,现在行业门槛是什么样的?以前企业对于程序员能力要求没有这么高,甚至十多年前你只要会写个“Hello World”,你都可以入门这个行业,所以以前要入门是完全可以入门的。
②现在也有一些优秀的年轻大牛,他们或许也是自学成才,但是他们一定是具备优秀的学习能力,优秀的自我管理能力(时间管理,静心坚持等方面)以及善于发现问题并总结问题。
如果说你认为你的目标十分明确,能做到第②点所说的几个点,以目前的市场来看,你才真正的适合去自学。

除此之外,对于绝大部分人来说,报班一定是最好的一种快速成长的方式。但是有个问题,现在市场上的培训机构质量参差不齐,如果你没有找准一个好的培训班,完全是浪费精力,时间以及金钱,这个需要自己去甄别选择。

我个人建议线上比线下的性价比更高,线下培训价格基本上没2W是下不来的,线上教育现在比较成熟了,此次疫情期间,学生基本上都感受过线上的学习模式。相比线下而言,线上的优势以我的了解主要是以下几个方面:
①价格:线上的价格基本上是线下的一半;
②老师:相对而言线上教育的师资力量比线下更强大也更加丰富,资源更好协调;
③时间:学习时间相对而言更自由,不用裸辞学习,适合边学边工作,降低生活压力;
④课程:从课程内容来说,确实要比线下讲的更加深入。

应该学哪些技术才能达到企业的要求?(下图总结)

Java全套资料免费领取方式:戳这里

格:线上的价格基本上是线下的一半;
②老师:相对而言线上教育的师资力量比线下更强大也更加丰富,资源更好协调;
③时间:学习时间相对而言更自由,不用裸辞学习,适合边学边工作,降低生活压力;
④课程:从课程内容来说,确实要比线下讲的更加深入。

应该学哪些技术才能达到企业的要求?(下图总结)

Java全套资料免费领取方式:戳这里

[外链图片转存中…(img-QqRKeWRz-1625558006822)]

[外链图片转存中…(img-Eb5NYKCX-1625558006825)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值