蚂蚁金服资深工程师面试经验分享

蚂蚁Java一面

1.二叉搜索树和平衡二叉树有什么关系,强平衡二叉树(AVL树)和弱平衡二叉树

(红黑树)有什么区别

2. B树和B+树的区别,为什么MySQL要使用B+树

3. HashMap如何解决Hash冲突

通过引入单向链表来解决Hash冲突。当出现Hash冲突时,比较新老key值是否相等,

如果相等,新值覆盖旧值。如果不相等,新值会存入新的Node结点,指向老节点,形成

链式结构,即链表。

当Hash冲突发生频繁的时候,会导致链表长度过长,以致检索效率低,所以JDK1.8之

后引入了红黑树,当链表长度大于8时,链表会转换成红黑书,以此提高查询性能。

4. epoll和poll的区别,及其应用场景

select和epoll都是I/O多路复用的方式,但是select是通过不断轮询监听socket实

现,epoll是当socket有变化时通过回掉的方式主动告知用户进程实现

参考文章:https://www.cnblogs.com/hsmwlyl/p/10652503.html

5.简述线程池原理,FixedThreadPool用的阻塞队列是什么?

6. sychronized和ReentrantLock的区别

(1)ReentrantLock显示获得、释放锁,synchronized隐式获得释放锁

(2)ReentrantLock可响应中断、可轮回,synchronized是不可以响应中断的,为处理

锁的不可用性提供了更高的灵活性

(3)ReentrantLock是API级别的,synchronized是JVM级别的

(4)ReentrantLock可以实现公平锁

(5)ReentrantLock通过Condition可以绑定多个条件

7. sychronized的自旋锁、偏向锁、轻量级锁、重量级锁,分别介绍和联系

8. HTTP有哪些问题,加密算法有哪些,针对不同加密方式可能产生的问题,及其

HTTPS是如何保证安全传输的

HTTP的不足:

通信使用明文,内容可能会被窃听;

不验证通信方的身份,因此有可能遭遇伪装;

无法证明报文的完整性,有可能已遭篡改;

常用加密算法:MD5算法、DES算法、AES算法、RSA算法



蚂蚁Java二面

1.设计模式有哪些大类,及熟悉其中哪些设计模式

创建型模式、结构型模式、行为型模式

2. volatile关键字,他是如何保证可见性,有序性

3. Java的内存结构,堆分为哪几部分,默认年龄多大进入老年代

Java的内存结构:程序计数器、虚拟机栈、本地方法栈、堆、方法区。

Java虚拟机根据对象存活的周期不同,把堆内存划分为几块,一般分为新生代、老年代

和永久代。

默认的设置下,当对象的年龄达到15岁的时候,也就是躲过15次Gc的时候,他就

会转移到老年代中去躲过15次GC之后进入老年代。

4. ConcurrentHashMap如何保证线程安全,jdk1.8有什么变化

JDK1.7:使用了分段锁机制实现ConcurrentHashMap,ConcurrentHashMap在对象中保存了一个Segment数组,即将整个Hash表划分为多个分段;

而每个Segment元素,即每个分段则类似于一个Hashtable;这样,在执行put操作时

首先根据hash算法定位到元素属于哪个Segment,然后对该

Segment加锁即可。因此,ConcurrentHashMap在多线程并发编程中可是实现多线程

put操作,不过其最大并发度受Segment的个数限制。

JDK1.8:底层采用数组+链表+红黑树的方式实现,而加锁则采用CAS和synchronized

实现

5.为什么ConcurrentHashMap底层为什么要红黑树

因为发生hash冲突的时候,会在链表上新增节点,但是链表过长的话会影响检索效

率,引入红黑书可以提高插入和查询的效率。

6.如何做的MySQL优化

MySQL的优化有多种方式,我们可以从以下几个方面入手:

存储引擎的选择、字段类型的选择、索引的选择、分区分表、主从复制、读写分离、

SQL优化。详细优化请查看参考文章

7.讲一下oom以及遇到这种情况怎么处理的,是否使用过日志分析工具



蚂蚁Java三面

1.项目介绍

2.你们怎么保证Redis缓存和数据库的数据一致性?

可以通过双删延时策略来保证他们的一致性。

3. Redis缓存雪崩?击穿?穿透?

缓存雪崩:缓存同一时间大面积的失效,所以,后面的请求都会落到数据库上,造成数

据库短时间内承受大量请求而崩掉。

缓存击穿:key对应的数据存在,但在redis中过期,此时若有大量并发请求过来,这

些请求发现缓存过期一般都会从后端DB加载数据并回设到缓存,这个时候大并发的请求

可能会瞬间把后端DB压垮。

缓存穿透:key对应的数据在数据源并不存在,每次针对此key的请求从缓存获取不

到,请求都会到数据源,从而可能压垮数据源。比如用一个不存在的用户id获取用户信

息,不论缓存还是数据库都没有,若黑客利用此漏洞进行攻击可能压垮数据库。

4.你熟悉哪些消息中间件,有做过性能比较?

差不多整个过程就是这样啦,希望对大家有所帮助吧。


#面经##蚂蚁集团##社招##Java工程师#
全部评论
阿里社招不写算法题么?
2 回复 分享
发布于 2021-08-06 16:49
怎么感觉像是校招
1 回复 分享
发布于 2022-01-30 12:34
这几年工作经验
1 回复 分享
发布于 2021-08-10 23:12
感谢楼主的分享,我也是java一年准备面试,请问楼主是几年经验
1 回复 分享
发布于 2021-08-07 00:16
**无情,全是八股文🤣l🤣
4 回复 分享
发布于 2021-08-23 10:32
老哥几年经验啊?没有问项目嘛?
点赞 回复 分享
发布于 2021-08-06 10:15

相关推荐

#牛客AI配图神器#攒攒好运~手撕:两个文件各有一亿行字符串,写一个算法找两个文件中相同的字符串问题:介绍你的一个后端项目介绍RPC项目介绍为什么你拆了这几个模块如果某一台机器下线了,应该怎么处理Java的锁用过哪些synchronized 和 ReentrantLocksynchronized底层原理假如多个线程竞争一个被synchronized锁上的资源,假如有t1,t2,t3这几个线程,如果t1拿到了,那么这是t2t3怎么办,如果t1用完了,释放锁之后,那么t2t3怎么知道?之后又是怎么竞争给你一个线程池,corePoolSize = 10, maximumPoolSize = 30, workQueue.size() = 100, 问第几个任务过来的时候,线程数量能够扩大到最大的数量30超过了会怎么样线程有很多创建方式,他的演进是怎么样的,为什么后面又有了线程池你觉得线程池主要解决什么问题分布式锁都有哪些类型的实现用redis实现分布式锁的几个关键参数分别是什么作用?如key,value,过期时间WatchDog是干嘛的如果获取分布式锁后,业务执行过程中抛异常了怎么办如果没有用catch捕获呢那什么情况下,业务逻辑时间比过期时间短,但是仍然会用到过期时间释放锁是怎么实现的?里面可能出现什么问题需要考虑如果出现线程安全问题,比如过期时间10s,业务逻辑执行也是10s,那么如果先过期,然后另一个线程拿到了分布式锁,那么业务逻辑执行删除时候就直接把别人的锁删了,这个问题怎么解决Redis的高可用是怎么做的MySQL怎么实现乐观锁悲观锁数据库加了索引为什么可以变快?假如我没有学过计算机,应该怎么解释用索引的过程中需要注意哪些#蚂蚁##暑期##实习##Java##后端#
查看25道真题和解析
点赞 评论 收藏
分享
TimeLine: 3.13笔试、3.18一面、3.20二面、3.24HR面一面【1h】1. 自我介绍2. 实习拷打3. 一个方法中可能有很多操作,比如数据库读写,调用RPC等,怎么保证事务性【重试 + 分布式事务】4. 2PC5. CompletableFuture原理 + 使用6. 慢查询7. 主键索引,二级索引,聚簇索引,非聚簇索引8. 联合索引9. 当前读,快照读10. 当前读加的是行锁还是表锁【行锁,记录锁】11. 事务隔离级别12. 缓存穿透,缓存击穿,缓存雪崩13. Redis hash的存储【Redis7之前 哈希表 + ziplist,Redis7 哈希表 + listpack】14. 什么时候会进行 ReHash 操作【负载因子】15. 消息队列如何保证不丢失,不重复16. 说一个自己最有成就感的事情二面【1h】1. 自我介绍2. 实习拷打3. ConcurrentHashMap4. CMS,G1,ZGC5. 分布式事务,2PC6. 事务隔离级别7. Redis 分布式怎么保证数据不丢失【持久化 + 主从分离,主库失效,从库选举】8. 如果线上环境有两套索引,我们现在使用索引A会出现慢查询问题,如何不停机切换到索引B【没答上来,然后面试官说有点超纲,说没事hh】9. 闲聊,介绍业务HR面【30min】1. 自我介绍2. 实习经历询问3. 最有难点的一个case4. 对于 AI 方面的思考感觉HR面答得一般,希望能有好运!#蚂蚁##阿里##阿里巴巴#
查看23道真题和解析
点赞 评论 收藏
分享
评论
8
212
分享

创作者周榜

更多
牛客网
牛客企业服务