匪夷所思?双非本末的我是如何六面阿里 --最终斩获Java岗P7offer

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注Java)
img

正文

第一轮面试是电话面,以基础知识为主,前后大概2个小时左右,这个阶段我是比较紧张的。

  • 先自我介绍,包含日常工作

  • 多线程,ThreadLocal,问了父子线程怎么共享数据 interitableThreadLocals

  • Lock和Sync的区别

  • AQS原理(执行过程源码,入队出队的细节,源码细节)

  • CountDownLatch和CyclicBarrier的区别是什么源码级别

  • volatile从指令重排序,内存屏障

  • 数据库,MySQL索引,执行计划、count1*区别、举例优化sql、MVCC和事务隔离级别的关系、间隙锁、行锁

  • JVM调优(可达性分析算法中根节点有哪些、cms和G1区别、怎样GC调优、怎样排查CPU彪高、内存彪高、逃逸分析)

  • redis数据结构、跳跃表、redis qps能上多少,怎么知道的、sentinel和cluster区别和各自适用场景、redis cluster集群同步过程、redis单线程为什么快、多大叫大key、热key产生原因和后果以及怎么解决、本地缓存需要高时效性怎么办?

  • spring的作用、spring循环依赖怎么解决(说出三级缓存源码细节)、spring aop原理(动态代理)、spring bean生命周期(源码细节,以及各个位置的设计思路,有什么可扩展的)

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

  • 项目中碰到的问题。

  • 为什么换工作,如果通过会直接说有笔试题,和你确认笔试时间。

第二轮:

第二轮是笔试,总共两道题,第一题是写代码,第二题是写技术方案。

  • 主要是以查询为主,考察锁粒度、时间粒度上的细节点。(详细省略)

第三轮:

第三轮是现场面试,这一轮面试以解决方案为主,前后大概约1小时20分钟。

  • 缓存穿透,让我设计一个防止缓存穿透的解决方案,简单的就是存null值,但肯定会深究,可以结合布隆过滤器,设计分布式系统,里面又会问到流量分发到具体过滤器服务的方式,比如一致性hash算法,怎么调用?比如dubbo直连、等等细节会边说边问。

  • 有没有做限流,设计一个侵入性最小的限流服务。

  • 项目中碰到的问题,最好说框架本身问题,能体现个人能力,也避免问题太低级被面试官看low,刚好之前有发现一个dubbo的bug,所以这问题应该回答的还可以。

  • 为什么换工作,每轮都会问,这个得想好。

第四轮:

交叉面,项目为主,时间大概为40分钟,问的内容不多,这个阶段我个人的状态比较放松了,与面试官交谈的方式也自然了许多。

  • 介绍最熟悉的项目,业务上有没有什么优化点;和同行业其他公司的差距和优势(估计是P7的标准问题,总之我回答得不是太好)

  • Dubbo服务调用过程

  • NIO、BIO区别,NIO解决了什么问题,Netty线程模型(源码拷问)。

  • MQ相关

第五轮:

这轮面试真的让我比较为难了,面试官问什么问题都会问到具体的数值,状态又变紧张了,如履薄冰啊。

  • 项目介绍

  • 听到说做了限流,限流标准(并发数? qps?并发数和qps关系?说出了5种限流方案和对应算法原理)

  • dubbo调用端怎么在jvm中生成对应服务?dubbo服务端和调用端超时时间设置和区别、dubbo长连接。

  • mysql行锁最大并发数?(秒杀项目指出)

  • 设计秒杀系统,我说的异步的方式,会问怎么优化?改为了同步的方式,异步和同步区别? 然后我也问了阿里那边

  • 碰到哪些技术难点?怎么解决?有没有参考其他大厂?其他大厂方案什么样的?有没有关注阿里这边最新的技术?

  • 刚刚的秒杀系统,会涉及到多个库表的更新,分布式事务怎么解决,我说的消息最终一致性,异步?有没有更好的方案?同步TCC方式,TCC方式原理?(三个阶段的具体实现)

第六轮:

总监面,主要是自我介绍和项目介绍,聊天的方式比较舒服,大部分是对你的整体价值观做宏观的把控(比如上进心,责任心,心态,工作激情等,差不多15分钟就结束了。

  • 说了自己的项目

  • 主要用到的架构,做了些什么?

  • 比较复杂的业务逻辑讲一下?

阿里6轮面试经历完整版(含答案和解析):

由于文章篇幅有限,完整版的面试题和答案解析就整理在PDF文档里,如果你需要完整版的,直接私信我「阿里面试」获取下载方式吧。

太为难我了,阿里面试了7轮(5年经验,拿下P7岗offer)

太为难我了,阿里面试了7轮(5年经验,拿下P7岗offer)

友情提醒:下部分涉及到的内容比较多,更多资料整理在文档里,需要的朋友转发+关注后添加下方图中VX即可

===================================================================================================================================================================================================

面试阿里之前,我流了多少汗?

==============

1.梳理知识

一般的面试,会被问到JVM原理、多线程、数据结构和算法、高并发、设计模式等内容,这都是一名普通Java开发人员的知识结构,那么阿里P7肯定是需要具备更多的知识树,需要掌握更全面的知识体系,所以就需要对知识进行一个系统的梳理了。

对标P7,我梳理的知识体系如下:

  • 筑基必备技能:并发编程,JVM,网络编程与高效IO,Mysql,Tomcat

  • 设计思想与开源框架:SSM(Spring+SpringMVC+MyBatis)

  • 性能直线提升架构技术:ZK,Nginx,RabbitMQ,RocketMQ,Kafka,elastic

  • 高效存储让项目性能起飞:Redis,MongoDB,MySQL,Mycat

  • 分布式扩展到微服务架构:SpringBoot,SpringCloud,SpringCloud Alibaba,Docker,K8S

太为难我了,阿里面试了7轮(5年经验,拿下P7岗offer)

太为难我了,阿里面试了7轮(5年经验,拿下P7岗offer)

总结

其他的内容都可以按照路线图里面整理出来的知识点逐一去熟悉,学习,消化,不建议你去看书学习,最好是多看一些视频,把不懂地方反复看,学习了一节视频内容第二天一定要去复习,并总结成思维导图,形成树状知识网络结构,方便日后复习。

这里还有一份很不错的《Java基础核心总结笔记》,特意跟大家分享出来

目录:

部分内容截图:

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-0A8M41rV-1713455487938)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 7
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue-Cropper是一个基于Vue.js的图片裁剪组件,可以轻松地将图片裁剪成不同的尺寸和比例。以下是使用Vue-Cropper的步骤: 1. 安装Vue-Cropper ``` npm install vue-cropper --save ``` 2. 引入Vue-Cropper 在需要使用Vue-Cropper的组件中引入: ``` import VueCropper from 'vue-cropper' ``` 3. 使用Vue-Cropper 在模板中添加Vue-Cropper组件,并绑定相关属性和方法: ``` <template> <div> <vue-cropper ref="cropper" :src="imageUrl" :aspect-ratio="aspectRatio" :output-size="outputSize" :guides="false" :scalable="true" :zoomable="true" :view-mode="1" :drag-mode="cropType" :auto-crop-area="0.7" @cropmove="onCropMove" @cropend="onCropEnd" ></vue-cropper> <button @click="cropImage">裁剪图片</button> </div> </template> <script> import VueCropper from 'vue-cropper' export default { components: { VueCropper }, data() { return { imageUrl: '', aspectRatio: NaN, cropType: 'crop', outputSize: { width: 200, height: 200 } } }, methods: { onCropMove() { console.log('onCropMove') }, onCropEnd() { console.log('onCropEnd') }, cropImage() { this.$refs.cropper.getCroppedCanvas().toBlob((blob) => { // 处理裁剪后的图片 }, 'image/jpeg') } } } </script> ``` 4. 属性和方法说明 - `src`:需要裁剪的图片地址。 - `aspect-ratio`:裁剪框的宽高比例,可以是数字或NaN(自由比例)。 - `output-size`:输出图片的尺寸。 - `guides`:是否显示裁剪框的辅助线。 - `scalable`:是否允许缩放裁剪框。 - `zoomable`:是否允许缩放图片。 - `view-mode`:显示模式,0表示自由模式,1表示限制在裁剪框内。 - `drag-mode`:拖动模式,crop表示裁剪模式,move表示移动模式。 - `auto-crop-area`:自动裁剪区域的大小比例。 - `@cropmove`:裁剪框移动时触发的事件。 - `@cropend`:裁剪结束时触发的事件。 - `getCroppedCanvas()`:获取裁剪后的Canvas对象。 - `getCroppedCanvas(options)`:获取根据选项裁剪后的Canvas对象,选项包括:`width`、`height`、`fillColor`、`imageSmoothingEnabled`、`imageSmoothingQuality`、`outputType`。 以上就是使用Vue-Cropper的基本步骤和属性方法说明,希望能对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值