和阿里大佬的技术面谈,源码+原理+手写框架

2023-11-10 22:40

本文主要是介绍和阿里大佬的技术面谈,源码+原理+手写框架,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最重要的话

2021年,真希望行业能春暖花开。

去年由于疫情的影响,无数行业都受到了影响,互联网寒冬下,许多程序员被裁,大环境格外困难。

我被公司裁掉后,便着急地开始找工作,一次次地碰壁,完全消磨掉了自己的信心,突然感受到,面试已经越来越难了。

于是,我开始调整状态,着重于深耕技术知识,似乎一切开始了好转,最后斩获p7岗offer。

于是乎,我想把我的学习经历以及面试几十家互联网企业总结下来的面试经历分享给我的同行(Java程序员),希望你在金三银四,感受春暖花开!

字节跳动

  • ⾯试前
  • ⼀⾯
  • ⼆⾯
  • ⼩结

凭借这些Java知识文档我收获了蚂蚁、拼多多、字节跳动Offer

⾯试前

头条的⾯试是三家⾥最专业的,每次⾯试前有专⻔的HR和你约时间,确定OK后再进⾏⾯试。每次都是通过视频⾯试,因为都是之前都是电话⾯或现场⾯,所以视频⾯试还是有点不⾃然。也有⼈觉得视频⾯试体验很赞,当然萝⼘⻘菜各有所爱。最坑的⼆⾯的时候对⽅⾯试官的⽹络⽼是掉线,最后很冤枉的挂了(当然有⼀些点答得不好也是原因之⼀)。所以还是有点遗憾的。

字节一面:

  • 先⾃我介绍下
  • 聊项目,逆向系统是什么意思
  • 聊项目,逆向系统用了哪些技术
  • 线程池的线程数怎么确定?
  • 如果是IO操作为主怎么确定?
  • 如果计算型操作⼜怎么确定?
  • Redis熟悉么,了解哪些数据结构?(说了zset) zset底层怎么实现的?(跳表)
  • 跳表的查询过程是怎么样的,查询和插⼊的时间复杂度?(说了先从第⼀层查找,不满⾜就下沉到第⼆层找,因为每⼀层都是有序的,写⼊和插⼊的时间复杂度都是O(logN))
  • 红⿊树了解么,时间复杂度?(说了是N叉平衡树,O(logN))
  • 既然两个数据结构时间复杂度都是O(logN),zset为什么不⽤红⿊树(跳表实现简单,踩坑成本低,红⿊树每次插⼊都要通过旋转以维持平衡,实现复杂)
  • 点了点头,说下Dubbo的原理?(说了服务注册与发布以及消费者调⽤的过程)踩过什么坑没有?(说了dubbo异常处理的和打印accesslog的问题)
  • CAS了解么?(说了CAS的实现)还了解其他同步机制么?(说了synchronize以及两者的区别,⼀个乐观锁,⼀个悲观锁)
  • 那我们做⼀道题吧,数组A,2*n个元素,n个奇数、n个偶数,设计⼀个算法,使得数组奇数下标位置放置的都是奇数,偶数下标位置放置的都是偶数
  • 先说下你的思路(从0下标开始遍历,如果是奇数下标判断该元素是否奇数,是则跳过,否则从该位置寻找下⼀个奇数)
  • 下⼀个奇数?怎么找?(有点懵逼,思考中。。)
  • 有思路么?(仍然是先遍历⼀次数组,并对下标进⾏判断,如果下标属性和该位置元素不匹配从当前下标的下⼀个遍历数组元素,然后替换)
  • 你这样时间复杂度有点⾼,如果要求O(N)要怎么做(思考⼀会,答道“定义两个指针,分别从下标0和1开始遍历,遇⻅奇数位是是偶数和偶数位是奇数就停下,交换内容”)
  • 时间差不多了,先到这吧。你有什么想问我的?

字节二面:

  • ⾯试官和蔼很多,你先介绍下⾃⼰吧
  • 你对服务治理怎么理解的?
  • 项⽬中的限流怎么实现的?(Guava ratelimiter,令牌桶算法)
  • 具体怎么实现的?(要点是固定速率且令牌数有限)
  • 如果突然很多线程同时请求令牌,有什么问题?(导致很多请求积压,线程阻塞)
  • 怎么解决呢?(可以把积压的请求放到消息队列,然后异步处理)
  • 如果不⽤消息队列怎么解决?(说了RateLimiter预消费的策略)
  • 分布式追踪的上下⽂是怎么存储和传递的?(ThreadLocal + spanId,当前节点的spanId作为下个节点的⽗spanId)
  • Dubbo的RpcContext是怎么传递的?(ThreadLocal)主线程的ThreadLocal怎么传递到线程池?(说了先在主线程通过ThreadLocal的get⽅法拿到上下⽂信息,在线程池创建新的ThreadLocal并把之前获取的上下⽂信息设置到ThreadLocal中。这⾥要注意的线程池创建的ThreadLocal要在finally中⼿动remove,不然会有内存泄漏的问题)
  • 你说的内存泄漏具体是怎么产⽣的?(说了ThreadLocal的结构,主要分两种场景:主线程仍然对ThreadLocal有引⽤和主线程不存在对ThreadLocal的引⽤。第⼀种场景因为主线程仍然在运⾏,所以还是有对ThreadLocal的引⽤,那么ThreadLocal变量的引⽤和value是不会被回收的。第⼆种场景虽然主线程不存在对ThreadLocal的引⽤,且该引⽤是弱 引⽤,所以会在gc的时候被回收,但是对⽤的value不是弱引⽤,不会被内存回收,仍然会造成内存泄漏)
  • 线程池的线程是不是必须⼿动remove才可以回收value?(是的,因为线程池的核⼼线程是⼀直存在的,如果不清理,那么核⼼线程的threadLocals变量会⼀直持有ThreadLocal变量)
  • 那你说的内存泄漏是指主线程还是线程池?(主线程 )
  • 可是主线程不是都退出了,引⽤的对象不应该会主动回收么?(⾯试官和内存泄漏杠上了),沉默了⼀会。。。
  • 那你说下SpringMVC不同⽤户登录的信息怎么保证线程安全的?(刚才解释的有点懵逼,⼀下没反应过来,居然回答成锁了。⼤脑有点晕了,此时已经⼀个⼩时过去了,感觉情况不妙。。。)
  • 这个直接⽤ThreadLocal不就可以么,你⻅过SpringMVC有锁实现的代码么?(有点晕菜。。。)我们聊聊mysql吧,说下索引结构(说了B+树)
  • 为什么使⽤B+树?( 说了查询效率⾼,O(logN),可以充分利⽤磁盘预读的特性,多叉树,深度⼩,叶⼦结点有序且存储数据)
  • 什么是索引覆盖?(忘记了。。。 )
  • Java为什么要设计双亲委派模型?
  • 什么时候需要⾃定义类加载器?
  • 我们做⼀道题吧,⼿写⼀个对象池
  • 有什么想问我的么?(感觉我很多点都没答好,是不是挂了(结果真的是) )

⼩结

头条的⾯试确实很专业,每次⾯试官会提前给你发⼀个视频链接,然后准点开始⾯试,⽽且考察的点都⽐较全。

⾯试官都有⼀个特点,会抓住⼀个值得深⼊的点或者你没说清楚的点深⼊下去直到你把这个点讲清楚,不然⾯试官会觉得你并没有真正理解。⼆⾯⾯试官给了我⼀点建议,研究技术的时候⼀定要去研究产⽣的背景,弄明⽩在什么场景解决什么特定的问题,其实很多技术内部都是相通的。很诚恳,还是很感谢这位⾯试官⼤⼤。

最后

权威指南-第一本Docker书

引领完成Docker的安装、部署、管理和扩展,让其经历从测试到生产的整个开发生命周期,深入了解Docker适用于什么场景。并且这本Docker的学习权威指南介绍了其组件的基础知识,然后用Docker构建容器和服务来完成各种任务:利用Docker为新项目建立测试环境,演示如何使用持续集成的工作流集成Docker,如何构建应用程序服务和平台,如何使用Docker的API,如何扩展Docker。

总共包含了:简介、安装Docker、Docker入门、使用Docker镜像和仓库、在测试中使用Docker、使用Docker构建服务、使用Fig编配Docke、使用Docker API、获得帮助和对Docker进行改进等9个章节的知识。

image

image

image

image

关于阿里内部都在强烈推荐使用的“K8S+Docker学习指南”—《深入浅出Kubernetes:理论+实战》、《权威指南-第一本Docker书》,看完之后两个字形容,爱了爱了!

如果你也爱了,点击这里免费下载:“K8S+Docker”学习指南

后两个字形容,爱了爱了!

如果你也爱了,点击这里免费下载:“K8S+Docker”学习指南

这篇关于和阿里大佬的技术面谈,源码+原理+手写框架的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/385771

相关文章

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

Nacos注册中心和配置中心的底层原理全面解读

《Nacos注册中心和配置中心的底层原理全面解读》:本文主要介绍Nacos注册中心和配置中心的底层原理的全面解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录临时实例和永久实例为什么 Nacos 要将服务实例分为临时实例和永久实例?1.x 版本和2.x版本的区别

Java中的登录技术保姆级详细教程

《Java中的登录技术保姆级详细教程》:本文主要介绍Java中登录技术保姆级详细教程的相关资料,在Java中我们可以使用各种技术和框架来实现这些功能,文中通过代码介绍的非常详细,需要的朋友可以参考... 目录1.登录思路2.登录标记1.会话技术2.会话跟踪1.Cookie技术2.Session技术3.令牌技

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事

C++ HTTP框架推荐(特点及优势)

《C++HTTP框架推荐(特点及优势)》:本文主要介绍C++HTTP框架推荐的相关资料,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Crow2. Drogon3. Pistache4. cpp-httplib5. Beast (Boos

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3

电脑系统Hosts文件原理和应用分享

《电脑系统Hosts文件原理和应用分享》Hosts是一个没有扩展名的系统文件,当用户在浏览器中输入一个需要登录的网址时,系统会首先自动从Hosts文件中寻找对应的IP地址,一旦找到,系统会立即打开对应... Hosts是一个没有扩展名的系统文件,可以用记事本等工具打开,其作用就是将一些常用的网址域名与其对应

Web技术与Nginx网站环境部署教程

《Web技术与Nginx网站环境部署教程》:本文主要介绍Web技术与Nginx网站环境部署教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Web基础1.域名系统DNS2.Hosts文件3.DNS4.域名注册二.网页与html1.网页概述2.HTML概述3.