自信,紧张,焦虑,意外?蚂蚁金服难忘的四面经历,真的太刺激了

简介: 前段时间,蚂蚁金服的热度可不小,互联网圈人人都在讨论它上市的事情,实际上蚂蚁金服上市是迟早的事情。这一下,蚂蚁的员工含金量上升了不少,那我之前蚂蚁提前批这波面经,也是时候分享了。

前言

前段时间,蚂蚁金服的热度可不小,互联网圈人人都在讨论它上市的事情,实际上蚂蚁金服上市是迟早的事情。这一下,蚂蚁的员工含金量上升了不少,那我之前蚂蚁提前批这波面经,也是时候分享了。

这次面试,可以说是一波三折,波涛汹涌了,原本我是一个挺自信的人的,所以在面试前我算是处于一个斗志昂扬的状态,奈何在经历一面二面意志力被消磨了不少,虽然三面准备充足,但整体下来对自己表现不满意,所以以为是没戏了,没想到意外接来了HR面的通知,于是就这么意外的拿到了offer。

下面就对这次蚂蚁金服的面试体验进行一个分享,由于面试题比较多,所以只挑选了一些有针对性的核心题放在这里解析,如果你需要完整pdf版,可以点击此处来获取就可以了!

蚂蚁金服意外的第一面

1、讲一讲ArrayList和LinkedList区别?

  • ArrayList 是一个可改变大小的数组。当更多的元素加入到ArrayList中时,其大小将会动态地增长。内部的元素可以直接通过get与set方法进行访问,因为ArrayList本质上就是一个数组,
  • LinkedList 是一个双链表,在添加和删除元素时具有比ArrayList更好的性能.但在get与set方面弱于ArrayList。
  • 当然,这些对比都是指数据量很大或者操作很频繁的情况下的对比,如果数据和运算量很小,那么对比将失去意义。

2、什么情况会造成内存泄漏?

  • 在Java中,内存泄漏就是存在一些被分配的对象,这些对象有下面两个特点:
  • 首先,这些对象是可达的,即在走向图中,存在通路可以与其相连;
  • 其次,这些对象是无用的,即程序以后不会再使用这些对象。
  • 如果对象满足这两个条件,这些对象就可以判定为Java中的内存泄漏,这些对象不会被GC所回收,然而它却占用内存。

3、什么是线程死锁,如何解决 ?

4、红黑树是什么?怎么实现?时间复杂度

5、TCP三次握手?

蚂蚁金服突然的第二面

1、Storm怎么保证一致性 ?

  • Storm是一个分布式的流处理系统,利用anchor和ack机制保证所有tuple都被成功处理。如果tuple出错,则可以被重传,但是如何保证出错的tuple只被处理一次呢?Storm提供了一套事务性组件Transaction Topology,用来解决这个问题。
  • Transactional Topology目前已经不再维护,由Trident来实现事务性topology,但是原理相同。

2、说一下hashmap以及它是否线程安全?

3、十亿条淘宝购买记录,怎么获取出现最多的前十个 ?

  • 这是一道典型的有限内存的海量数据处理的题目。一般这类题目的解答无非是以下几种:
  • 分治,hash映射,堆排序,双层桶划分,Bloom Filter,bitmap,数据库索引,mapreduce等。
  • 具体情形都有很多不同的方案。这类题目可以到网上搜索一下,了解下套路,后面就基本都会了。

4、平时有没有用linux系统,怎么查看某个进程 ?

ps aux|grep java 查看java进程
ps aux 查看所有进程
ps –ef|grep tomcat 查看所有有关tomcat的进程
ps -ef|grep --color java 高亮要查询的关键字
kill -9 19979 终止线程号位19979的进程

5、说一下Innodb和MySIAM的区别?

6、说一下jvm内存模型,介绍一下你了解的垃圾收集器 ?

  • 其实并没有jvm内存模型的概念。应该是Java内存模型或者jvm内存结构,这里面试者一定要听清楚问的是哪个,再回答。

7、其他问题

  • 100个有序的整型,如何打乱顺序?
  • 如何设计一个可靠的UDP协议?

蚂蚁金服准备充足的第三面

1、介绍一下hashmap?

  • HashMap真的是面试高频题,多次面试都问到了,一定要掌握。

2、介绍一下并发?

  • 这里可以把整个并发的体系都说下,包括volatile、synchronized、lock、乐观悲观锁、锁膨胀、锁降级、线程池等

3、银行账户读写怎么做?

  • 我说了读写锁以及可能出现死锁问题

4、说一下关系型数据库和非关系型数据库的区别 ?

5、如何访问链表中间节点?

6、说下进程间通信,以及各自的区别?

  • 进程间通信是指在不同进程之间传播或交换信息。方式通常有管道(包括无名管道和命名管道)、消息队列、信号量、共享存储、Socket、Streams等。

7、访问淘宝网页的一个具体流程,从获取ip地址,到怎么返回相关内容?

蚂蚁金服十分焦虑的HR面

1、有没有遇到过什么比较大的挫折?

  • 这种问题主要考察面试者遇见困难是否能坚持下去,并且可以看出他的解决问题的能力。
  • 可以简单描述挫折,并说明自己如何克服,最终有哪些收获。

2、有之后清晰的职业规划吗?说说看

  • 表明自己决心,首先自己不准备继续求学了,必须找工作了。然后说下自己不会短期内换行业,或者换工作,自己比较喜欢,希望可以坚持几年看自己的兴趣再规划之类的。

3、说一下你对阿里的认识吧

  • 这个比较简答,夸就行了。

4、有什么崇拜的人吗?为什么?

5、最理想的就业城市是哪里?

6、说一件你自己记忆里印象最深刻的一件事吧

总结

实际上,提前批考察的更多的是基础知识,主要是因为现在的很多大公司都有自己在用的框架,基本上是进公司以后再去重新学习这些框架知识,所以基础部分是提前批考察的关键,看你的基础知识是否够扎实!

必备知识点包括:

  • 操作系统
  • Linxu
  • 数据库
  • 数据结构
  • 算法
  • java(基础、容器、高并发、jvm)
  • 计算机网络

面试蚂蚁金服,你必须要做好的功课

功课一:了解公司,摸清喜好,定制简历

我们都知道,蚂蚁金服是一家互联网金融公司,所以在对员工喜好和技术倾向方面与很多互联网公司不同,所以在面试蚂蚁金服之前,一定要了解清楚这家公司的信息,摸清好它们的喜好,这样才能有能力去定制简历,通过简历筛选的第一关。

在投蚂蚁金服之前,我特意把自己的简历进行了修改,也是参照的网上的模板,和自己旧版简历对比,确实加分不少。(可以点击此处来获取就可以了!免费领取18种简历模板)

简历模板-1

简历模板-2

功课二:梳理技术栈,提升广度和深度

  • 筑基必备技能:并发编程+JVM剖析+网络编程与高效IO+Mysql深度进阶+深入Tomcat
  • 性能直线提升架构技术:分布式架构+Zookeeper+Nginx+RabbitMQ+RocketMQ+Kafka
  • 高效存储让项目性能起飞:Redis+mongoDB+MySQL高可用+Mycat
  • 分布式扩展到微服务架构:SpringBoot+SpringCloud+SpringCloud Alibaba+docker+k8s
  • 设计思想解读开源框架:六大原则+设计模式+Spring5源码解读+SpringMVC框架源码解读+Mybatis源码

当然,这套技术路线图不完全要求全部掌握,尤其是对于刚工作的或经验不多的人来说,但作为程序员,我们需要具备这种提升自己技术广度和深度的思维,因此这条架构师发展路线图从基础-进阶-实战均涉及到了,非常全面具体。(附学习路线图+实战电子书+源码笔记,可以点击此处来获取就可以了!

功课三:刷刷历年真题,积累经验

对于应届生或是工作经验不足的程序员来说,刷题是应对面试最快捷最有效的方式,能够让自己迅速掌握面试公司的面试情况,至少能够应对50%以上的内容。

在面试蚂蚁金服之前,我就狠狠的刷了一波题,实际上问的内容都差不了太多,学会举一反三才是刷题的精髓之处。

关于刷题,我也准备了一套面试大礼包分享给大家:

面试题集锦

历年BAT等一线大厂面试专题

Java面试核心知识点

写在最后

罗马不是一天建成的!成为技术大牛的道路也不是一个月一年就能走完的,不仅仅软件开发这个行业如此,其他行业亦是如此。

刚踏上掉发路上的我,一直在努力!

以上文章内容中,涉及到的所有pdf文档资料均可以免费分享给你们,可以点击此处来获取就可以了!

相关文章
|
3月前
|
数据采集 人工智能 自动驾驶
《突破AI数据标注高成本枷锁,势在必行!》
在人工智能快速发展的背景下,数据标注作为AI模型训练的基础,其高成本问题成为制约行业发展的关键因素。主要体现在人力、时间和管理成本上,尤其是在复杂领域和大规模数据处理中。为解决这一难题,行业探索了多种创新方案:技术层面,自动化标注工具与半监督学习技术显著提升效率;商业模式上,分布式众包和专业平台降低运营成本;人才培养方面,校企合作与激励机制优化标注质量。尽管仍存挑战,但通过多方协同,有望推动AI数据标注行业的高效发展,助力AI技术广泛应用。
197 9
|
机器学习/深度学习 人工智能 自然语言处理
【Python机器学习】文本特征提取及文本向量化讲解和实战(图文解释 附源码)
【Python机器学习】文本特征提取及文本向量化讲解和实战(图文解释 附源码)
682 0
|
负载均衡 网络协议 Dubbo
微服务架构 | 3. 注册中心与服务发现
注册中心用来集中管理微服务,实现服务的注册,发现,检查等功能;
3291 2
微服务架构 | 3. 注册中心与服务发现
|
关系型数据库 MySQL Linux
倚天服务器与X86服务器业务部署差异
倚天服务器是一种基于ARM架构的服务器,与传统的X86服务器在硬件架构、操作系统和软件环境等方面存在一定的差异。本报告将重点从操作系统和软件安装包的版本差异两个方面进行详细说明。
518 56
|
9月前
|
人工智能 自然语言处理 安全
【通义】AI视界|谷歌推出AI搜索功能“问照片”,照片一问即得……
本文汇总了AI领域的最新动态,包括谷歌推出的“问照片”功能,使用户能用自然语言检索Google Photos;OpenAI的商业用户激增及ChatGPT的广泛应用;Anthropic发布的企业级AI助手Claude Enterprise;美英欧盟首个人工智能法律约束条约;OpenAI前首席科学家新公司获巨额融资;以及比尔·盖茨对AI前景的乐观展望与安全建议。
|
10月前
|
缓存 测试技术 API
从零到一:构建高效的 RESTful API 服务器
在当今的软件开发环境中,RESTful API 是实现系统间数据交互的关键组件。本文探讨了如何从头开始构建一个高效的 RESTful API 服务器,包括技术选型、架构设计、性能优化等方面的内容。我们将以 Python 的 Flask 框架为例,展示如何设计一个可扩展且高性能的 API 服务器,并提供实际代码示例来说明最佳实践。
|
移动开发 前端开发
基于若依的ruoyi-nbcio流程管理系统自定义业务回写状态的一种新方法(二)
基于若依的ruoyi-nbcio流程管理系统自定义业务回写状态的一种新方法(二)
143 2
|
算法
解密汉诺塔问题:递归与分治的经典探索
解密汉诺塔问题:递归与分治的经典探索
779 0
|
前端开发 JavaScript API
React使用Electron开发桌面端
React是一个流行的JavaScript库,用于构建Web应用程序。结合Electron框架,可以轻松地将React应用程序打包为桌面应用程序。以下是使用React和Electron开发桌面应用程序的步骤:
React使用Electron开发桌面端
RFM用户分层模型|原理+Python全流程实现
详细解读如何使用RFM模型进行用户分层(附代码)
RFM用户分层模型|原理+Python全流程实现