阅文暑期实习Java开发一二面面经

2020.6.9   更新

oc了!我来还愿了!!!
凉了两周,以为凉透了,今天hr小姐姐突然打电话给我,然后大概谈了一下就发了offer

电话结束就面了顺丰,yeshijava开发,个人感觉不是很难,面试官人也很好,问题都是非常基础的,微服务相关的没用过所以没回答,其他的都是基础
现在再求一个顺丰的offer!!!

我终于不是0offer了!希望各位不要着急再等等,是你的offer早晚都会来!



-------------------------------------------------------分割线--------------------------------------------------------------


听说发面经能攒人品拿offer,我也来试试,只能努力回忆回忆了,不一定完全一样但大差不差了
5.26连续两面中间隔2-3min左右

一面,40min左右

面试官大哥人特别好,性格也好,说话方式什么都好,吹爆阅文面试官

1.讲一下在校科研或者做项目的过程以及心得

2.简单说一下各个排序算法的时间复杂度

3.说一下平衡二叉树,B树(插入等问题)、B+树的特点

4.说到B+树就说一下Mysql的索引

5.聊一下事务隔离级别还有MVCC

6.AQS选一个(原子类、cutdownLatch、循环栅栏等)

7.并发包源码(hashMap问题、concurrenthashmap等)

8.Spring介绍,IOC、AOP(简单说了一下源码,忘了)以及如何解决循环依赖(忘记了,没答上来)

9.还有其他的一些小问题个人兴趣,对阅文的了解等

10.手撕算法,数组中找到重复数字,写了一种,又问有没有其他方法,面试官说了一种,我又说了两种,然后讨论了一下时间复杂度的问题


3min左右开始二面,35min左右

这个面试官大哥也很好,再次吹爆阅文面试官,这次属于场景发散思维解决问题的一些题目

1.上一轮面试感觉(面试官非常好,有几个小点没答出来,没准备好)

2.问了一下我做的项目,拿个模块有难点(我说我的项目过于简陋,没实现复杂功能,尴尬中。。。。)

3.那如何保证并发性(用事务)

4.其他的比如说扣款和扣票不在一个服务器(两阶段、本地事务、先冻结再操作,回答得有点迷,估计没跟上面试大哥的思路)

5.主从服务器传信息问题,数据库信息恢复

6.主服务器挂掉怎么办(答不出来,尴尬中。。。后来面试官老哥就一直引导我,最后说到了分布式,我恍然大悟,原来前面的铺垫都是分布式啊,但是我对分布式只了解过一点点,就把知道的都说了)

7.非关系型数据库

8.Spring中的事务还有隔离级别

10.用过读书软件的想法以及改进(我不爱看小说,就高中看过盗墓笔记。。。。,然后一开始说了乱七八糟的,老哥又开始引导我,我就往自己的研究方向说,建立社群关系等)

11.未来3年职业规划

12兴趣爱好

))))))))

差不多就这些了,至今0offer希望阅文爸爸收了我吧,许愿阅文offer,各位朋友加油吧!

#阅文##阅文集团##实习##Java工程师##面经#
全部评论
重复数字的话,如果明确告知范围可以把空间复杂度降到1(位运算),如果事先有序则可以二分查找把时间复杂度降到lg n ,否则应该是o(n) 和o(n)的复杂度
1 回复 分享
发布于 2020-05-28 11:23
楼主面试结果显示啥
点赞 回复 分享
发布于 2020-05-27 17:28
阅文有招实习吗。??
点赞 回复 分享
发布于 2020-05-27 16:39

相关推荐

虽然笔试没过,但还是参加一下AI面试,以下是记录总结。1.计算机网络:TCP的粘包问题(刚背的,可熟悉了)回答:在网络拥塞或者Nagle算法中,会将多个TCP包合在一起,但是TCP在传输中是以字节流形式的,粘在一起之后没办法区分包之间的边界,例如发送两个数据包Hello 和World,合在一起后,接收方收到的是HelloWorld。        解决办法主要有四个,第一个是固定数据包的大小,发生粘包后根据字节大小切分,但这样比较死板;        第二种是在数据包末尾加入"\n"的分隔符,但是在中间文本中出现了分隔符的话,需要进行转义;        第三种是在TCP报文前加入一个字段,记录这个包的大小,这种比较常用;        第四种是对协议进行限制,例如禁用Nagle算法,不允许合并数据包。2.Linux:grep如何使用(确实没准备)回答:完全不会。3.Java:装箱和拆箱是什么,举一个例子。回答:举了int型和Integer类的例子,一些接口使用的时候会发生拆箱和装箱(但我不太记得了)4.高并发:解决投票中刷票问题回答:使用IP检测,限制单个IP的高频访问。追问:要是对方使用代理IP,或者IP连接池该怎么解答回答:根据行为检测,刷票行为和个人投票行为肯定存在差异(但我不知道差异是什么)5.数据库:主键的作用是检索到这条数据的唯一标识,也用来构建聚簇索引。(应该还有其他作用但我忘了。)6.通用问题1:学习新技术的路线回答:阅读官方文档,对于难点搜索视频讲解或者Github文档;项目实战有问题去找熟悉项目的技术人员。        追问1:如何判断学习资料是否有用,是否走过弯路        回答:根据点赞量,Start量。        追问2:走过弯路后下次如何判断?        回答:根据文档关键词判断对我是否有帮助?7.通用问题2:你项目中遇到的难点怎么解决追问1:如何通过持续改进解决一个一直出现的问题追问2:如何平衡局部调优和整体的稳定性8.通用问题3:你未来3年的职业规划回答:1-2年熟悉公司技术栈,后续熟悉公司业务流程,做到技术和业务两手抓。最后给出DeepSeek的回答。1.计算机网络:TCP的粘包问题  TCP粘包问题是由于TCP是面向字节流的协议,发送端可能将多个数据包合并发送(如Nagle算法或网络拥塞),接收端无法区分数据边界。例如发送"Hello"和"World",接收端可能收到"HelloWorld"。 解决方案 :● 固定包长度 :每个包固定为相同长度(不足时填充),接收方按固定长度拆分。缺点是灵活性差,适合固定格式场景。● 分隔符 :在数据包末尾添加特殊字符(如\n),接收方按分隔符拆分。需处理数据中的转义字符(如HTTP头用\r\n\r\n)。● 头部声明长度 :在报文头部添加长度字段(如4字节表示包体长度),接收方先读头部,再按长度截取数据。这是最常用的方式(如HTTP的Content-Length)。● 禁用Nagle算法 :通过TCP_NODELAY选项关闭合并优化,但可能增加小包传输次数,影响性能。2.Linux:grep如何使用 grep用于文本搜索,常见用法:● 基本搜索 :grep "pattern" file.txt● 递归搜索目录 :grep -r "pattern" /path/to/dir● 忽略大小写 :grep -i "pattern" file.txt● 显示行号 :grep -n "pattern" file.txt● 反向匹配(排除)  :grep -v "pattern" file.txt● 正则表达式 :支持^(行首)、$(行尾)、.(任意字符)等,如grep "^start" file.txt。3.Java:装箱和拆箱是什么,举一个例子 ● 装箱(Autoboxing)  :将基本类型转换为包装类,如int → Integer。● 拆箱(Unboxing)  :将包装类转换为基本类型,如Integer → int。Integer a = 10;      // 自动装箱(底层调用Integer.valueOf(10))  int b = a;           // 自动拆箱(底层调用a.intValue())  4. 高并发:解决投票中刷票问题 ● 基础防御 :  IP限流 :限制同一IP单位时间内的请求次数(如Redis计数器+过期时间)。○ 用户鉴权 :要求登录后投票,限制每个用户的投票次数。○ 验证码 :在频繁请求时触发验证码(如滑动拼图、短信验证)。● 对抗代理/IP池 :  设备指纹 :通过浏览器指纹(UserAgent、Canvas渲染)、设备ID等标识唯一设备。○ 行为分析 :检测异常行为(如毫秒级连续投票、无页面停留直接提交)。○ 风控系统 :实时分析请求特征(IP地理分布、时间分布),拦截异常流量。● 业务层优化 :  异步队列削峰 :将投票请求放入消息队列,后端批量处理,避免瞬时高并发。5.  数据库:主键的作用 ● 唯一标识 :确保每行数据的唯一性(如自增ID、UUID)。● 聚簇索引 :InnoDB中主键默认作为聚簇索引,数据按主键顺序物理存储,加快检索速度。● 外键关联 :主键作为其他表的外键,维护数据一致性。● 优化查询 :主键查询最快(如WHERE id=1),避免全表扫描。●注意事项 :避免业务字段做主键(如身份证号),优先使用无意义的自增ID。●复合主键需谨慎,可能增加索引复杂度。6.  通用问题1:学习新技术的路线 ● 学习路径 :  官方文档 :掌握核心概念和最佳实践(如Spring Boot的Spring.io)。    ○ 实践项目 :通过小项目验证技术点(如用Redis实现分布式锁)。    ○ 源码与社区 :阅读源码、参与GitHub讨论(如Dubbo的Issue)。● 判断资料质量 :  筛选标准 :作者权威性(如Oracle认证工程师)、内容更新日期、社区评价(Stack Overflow投票)。    ○ 避免弯路 :优先选择官方推荐资源,再参考高星GitHub项目或经典书籍(如《Effective Java》)。● 持续改进 : 定期复盘学习效果,建立知识体系脑图,与团队分享经验。7.  通用问题2:项目难点解决  结构化回答(STAR模型)  :● 情境(Situation)  :在XX项目中,接口响应慢,导致超时报警。● 任务(Task)  :需在1周内将平均响应时间从2s优化至200ms内。● 行动(Action)  :  定位瓶颈 :通过Arthas追踪调用链,发现SQL查询耗时占80%。○ 优化SQL :添加索引、重构分页查询,减少全表扫描。○ 缓存引入 :对热点数据(如配置信息)增加Redis缓存。● 结果(Result)  :响应时间降至150ms,且通过压测验证稳定性。●平衡调优与稳定 :局部优化前评估影响范围,通过灰度发布观察效果。●监控核心指标(CPU、内存、错误率),确保优化不引发链式故障。8.  通用问题3:未来3年的职业规划 ● 短期(1年)  : 深入掌握公司技术栈(如微服务架构、中间件),成为团队核心开发。○参与高复杂度模块(如分布式事务、性能优化)。● 中期(2年)  : 提升架构设计能力,主导跨系统方案设计(如亿级流量系统)。○培养业务洞察力,推动技术与业务融合(如通过数据驱动产品决策)。● 长期(3年)  : 向技术管理者或架构师转型,负责技术选型与团队规划。○持续学习行业前沿(如云原生、AI工程化),保持技术敏感度。
美团AI面330人在聊 查看12道真题和解析
点赞 评论 收藏
分享
评论
3
10
分享

创作者周榜

更多
牛客网
牛客企业服务