2019蚂蚁金服面试总结(Java方向)
年初得蚂蚁垂青(本人非985/211,蚂蚁真的不是很在乎学历!!!),有了一次社招机会,前后经历三关,受益匪浅,在此与各位朋友分享经历与心得。
第一关:在线笔试
笔试题内容如下:
说明:
构建一个本地缓存,缓存的对象是用户ID以及部分用户的信息。
当从缓存中获取某个用户数据时,如果发现该用户数据上次更新时间超过30分钟,则需要更新一次该缓存。
1.需考虑多线程访问的情况。
2.请不要使用第三方类库实现。
3.可以添加适当日志。
4.可以有适当的伪代码。
补充:UserInfo结构
public class UserInfo {
private String userId;
private String userName;
private String cardNo;
//省略其它信息和getter 和setter
}
完成下面的代码
//: TODO 可自行定义需要的变量
/**
* 初始化用户信息缓存
*/
public void initUserInfoCache() {
//: TODO 完成此处的代码
}
/**
* 根据id从缓存中获取用户信息
*/
public UserInfo getUserInfoFromCacheById(String id) {
//: TODO 完成此处的代码
}
/**
* 根据id更新缓存用户信息
*/
public void updateUserInfoCache(String id) {
//: TODO 完成此处的代码
}
题目是让在 考虑多线程的情况下实现一个缓存,题目相对简单(经历过2016的阿里校招在线笔试,简答题难度至今 记(还)忆(是)犹(不)新(会)!!!),时间上要求宽松,24小时内答完即可。
第二关:一轮电话面试
笔试题提交完毕后,大约2天后,收到一个来自于杭州蚂蚁金服IP的固定电话,不巧当时正在另外一家单位面试,恰逢一面结束,等待二面的空隙里,没办法,接了电话果然是邀请马上进行一轮电面。内心是崩溃的...。和面试官说了暂时不方便,约了半小时后再开始,面试官很爽快的同意了。
一开始依旧是自我介绍,一面提问的问题很多,很杂,涉及面很广,着重于基础,共面了55分钟左右。事后回忆问题如下:
1.jvm内存管理和分配
2.Redis
3.数据库乐观锁
3.currenthashmap的缺点
4.数据库并发
5.dubbo的调用模式,序列化
6.事务的最大级别,跨库?跨表?
7.dubbo上游100万,下游10万,如何处理
8.用户一次请求访问web的详细过程(从浏览器到web服务器经历详细过程)
9.spring的bean的周期
10.详细说下参与的项目的架构
11.hashmap 触发红黑树
12.MySQL支持的跨库事务
...
第三关:二轮电话面试
距离一面过了约一周,二面姗姗来迟。与一面的Java基础相比,二面更偏重于提问 经历的项目的架构,以及使用的框架的底层原理。(突破了会用的范围,理解框架的底层实现原理很重要,但这个很容易忽略!)。内心忐忑的聊了45分钟左右,结束了二面。
事后回忆二面问题如下:
1.说一说你最近参与的印象最深的项目,项目的架构,用到哪些技术
2.说一说spring容器的实现方式
3.说一说redis缓存应用场景
4.说一说eletasic-job与其他job定时任务的区别,以及它的优点是什么
...
附框架学习图:
总结:蚂蚁还是很看重基础和对框架的原理的理解程度的,说白了,对使用的技术,要知其然也知其所以然。无论是框架还是JavaAPI,底层的研究理解永远不能停。 大道至简,知易行难。
欢迎做Java的工程师朋友们加入Java架构解析:923116658
群内提供免费的Java架构学习资料(里面有高可用、高并发、高性能及分布式、Jvm性能调优、Spring源码,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多个知识点的架构资料)合理利用自己每一分每一秒的时间来学习提升自己,不要再用"没有时间“来掩饰自己思想上的懒惰!趁年轻,使劲拼,给未来的自己一个交代!