蚂蚁金服面经:

一面技术面,过。

紧接着发了机式链接

机式题两道算法,在leetcode简单难度的题的基础上提出了一些新要求。接近中等难度。不会写,寄!

1.数据库

mysql索引结构

B+树,B树的区别

为什么同等数据量下,B+树的高度更低?树的高度低的好处?

b树子节点是链表?双向链表?这里用链表的作用?

sql如何优化

abc三个字段建立联合索引,用到a,c,怎么写sql把b也用上(这里不能重建索引;如果建立索引用什么命令)

哪些情况适合做索引

表里有百万级数据,查第100万条到110万条数据,怎么优化sql(和索引无关)

四个隔离级别,每个级别的事务问题

DB事务的原理(我只提到了undolog,和事务point,不太了解)

2.redis

雪崩、穿透、击穿

IO多路复用原理

3.hashmap

为什么要引入红黑树

哈希碰撞

4.springboot

springboot启动类注解,每个注解的作用

springboot原理

所有spring.factories里面的所有配置都会加载吗

5.spring

spring怎么解决的循环依赖问题(虽然是高频面试题,但我还是第一次被问到这个)

三级缓存的作用

BeanFactory、FactoryBean的去区别;FactoryBean的作用(第一次被问这个问题,没准备 QAQ)

6.锁

java锁了解吗

synchronized和lock的区别 重量级/轻量级

锁的原理(我直接说AQS,奈何太菜,AQS的细节没有battle过面试官,应该先说CAS再说AQS)

synchronized的原理是AQS吗

分布式锁可以用什么实现?(数据库/ZOOKEEPER/Redis/Redisson)

Redission实现分布式锁的原理(只说到了setnex)

锁续期怎么实现(看门狗机制)

锁重入(/(ㄒoㄒ)/~~,实现细节忘了)

7.项目亮点(10分钟)

一个亮点说的不到10分钟,会问有没有其他亮点

总结:一面整体不难,问题涉及项目和技术栈。

覆盖面还是比较广的

技术问题会从八股文开始问,但是由浅入深。比如索引的问题,从mysql的索引结构是什么问到叶子节点的数据结构的作用。

需要继续打磨项目亮点

索引和锁是技术重点,值得投入更多时间研究,尤其是CAS和AQS,如果和面试官把AQS聊好了,面试官应该会刮目相看

算法一如既往的烂,继续坚持刷算法喽

全部评论
约二面了吗
点赞 回复 分享
发布于 2023-07-23 16:30 上海
楼主请问一下这个怎么答啊 abc三个字段建立联合索引,用到a,c,怎么写sql把b也用上(这里不能重建索引;如果建立索引用什么命令)
点赞 回复 分享
发布于 2023-07-12 17:24 广东
社招吗?
点赞 回复 分享
发布于 2023-07-12 16:25 广东

相关推荐

05-09 15:21
门头沟学院 Java
- 在Java中,为什么String类要被final修饰?- ArrayList和LinkedList有什么区别?- 如何让ArrayList变成线程安全?- 你提到的`CopyOnWriteArrayList`的内部实现了解吗?- HashMap为什么线程不安全?多线程使用HashMap会导致哪些问题?(分为hash冲突以及不冲突两种情况)- ConcurrentHashMap如何解决多线程带来的问题?- 为什么不使用HashTable而是ConcurrentHashMap- HashTable与ConcurrentHashMap在性能上的区别是什么?- HashTable与ConcurrentHashMap在多线程性能上的区别是什么?- HashMap的默认负载因子是多少?为什么默认是0.75?- HashMap在什么情况时会转为红黑树?小于该值会不会转回链表?- 深拷贝和浅拷贝的区别是什么?如何实现这两种拷贝?- Java的反射机制为什么性能比直接调用慢?- 用Lambda表达式将List转为Map时,如何处理Key冲突(保留较大的Value)?- 如何用Lambda表达式将List转为Map,使相同Key的Value合并为List?- java中有两种动态代理,你能说一下是哪两种吗- error跟exception的区别- Java中有哪些实现锁的方式?- synchronized的锁升级过程是怎样的?- Lock类相比synchronized有哪些优势?- Spring Security的用户信息上下文存储在哪- ThreadLocal的原理是什么?实际应用场景除了保存登录信息有哪些?- volatile关键字的作用是什么?- 线程池参数如何设置(IO密集型任务,8核CPU)?- 线程工厂(ThreadFactory)的作用是什么?- 线程池去执行一个多线程任务的时候,有哪些提交方式- CountDownLatch若某个线程异常未调用`countDown()`,如何避免主线程阻塞?- G1垃圾回收器的工作原理是什么?- 双亲委派机制- Tomcat为什么打破双亲委派机制?- 联合索引(A,B)中,仅用B字段查询能否命中索引?- 索引下推优化在何种查询条件下会触发?- 对日期字段(包含时分秒)建立索引后,使用`BETWEEN`且格式化为年月日查询,能否命中索引?- Spring如何解决循环依赖?能否解决构造器注入的循环依赖,为什么不能?- MyBatis中`#{}`和`${}`的区别是什么?两者的生成SQL是否相同?- 扫码登录的完整流程是如何设计的(前后端协作)?- lua脚本中具体使用的命令
腾讯云智研发一面220人在聊
点赞 评论 收藏
分享
评论
4
52
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务