主頁 > 軟體設計 > 螞蟻金服Java面試六面總結,程序被血虐,沒想到最后成功拿下30K的offer

螞蟻金服Java面試六面總結,程序被血虐,沒想到最后成功拿下30K的offer

2020-10-20 19:20:01 軟體設計

前言

今天給大家分享一個小伙伴的螞蟻金服六面經驗,雖然在面試程序中被血虐,沒想到最后還是拿到了offer,
在這里插入圖片描述

一面

  • 介紹一下自己
  • 問專案經歷, 聊"資料同步"
  • 接著聊上了 K8S 的專案
  • 有沒有什么鉆研得比較深得技術?(我:kubernetes, golang, prometheus, java)
  • kubernetes 的架構是怎么樣的? 這個問題很大,拆成 apiserver、controller、kubelet、scheduler 講了一下
  • golang 與 java 的比較 這個問題又很大,當時主要對比了 vm、協程支持、面向物件和泛型的區別、以及自己對各自使用場景的一些理解
  • golang 的 gc 演算法 知道是三色標記,不過細節說不上來
  • 從無限的字符流中, 隨機選出 10 個字符 沒見過也沒想出來,查了一下是蓄水池采樣演算法,經典面試題,沒刷題吃虧了
  • 怎么擴展 kubernetes scheduler, 讓它能 handle 大規模的節點調度
  • 單節點提速:優選階段隨機取部分節點進行優選;水平擴展 scheduler 節點,pod 做一致性 hash 來決定由哪個scheduler 調度
  • 你有什么想問我的?

一面其實有點沒放開,面試官對我的回答沒有什么反饋和深入,所以我當時面完覺得自己其實已經掛了,后來收到二面電話著實吃驚了一下,

二面

  • 先聊了聊專案
  • 給 Prometheus 做了哪些改動?
  • 自研配置中心, 具體做了哪些內容?
  • 有用過 MySQL 的什么高級特性嗎? 這里不太理解,我問什么算高級特性,面試官就切換到了下一個問題
  • 配置中心的核心資料表是怎么設計的?
  • 為什么在業務里用 Redis, Redis 有什么優點? 單執行緒:并發安全;高性能;原語與資料結構豐富;采用廣泛,踩坑成本低
  • 對 Redis 里資料結構的實作熟悉嗎? 說了一個 zset 跳表
  • 用過 Redis 的哪些資料結構, 分別用在什么場景?
  • Java 初始化一個執行緒池有哪些引數可以配置, 分別是什么作用?
  • 自己寫的 Java 應用調優過哪些 JVM 引數, 為什么這么調優? 這個問住了,我只知道最大堆最小堆,開 G1,開 GC 日志以及 OOM dumper 這些基本的
  • 用 Jetty 的時候有沒有配什么引數, 為什么這么配?
  • Jetty QTP 等待佇列配置成無限的話, 你覺得好嗎? 會有什么問題嗎?
  • 用過 Linux Bash 里的哪些命令, 分別用它們干嘛?
  • 一道筆試題: 需要在給的鏈接中作答, 不能 google, 不能跳出, 不能用 IDE:
    題目是這樣的: 啟動兩個執行緒, 一個輸出 1,3,5,7…99, 另一個輸出 2,4,6,8…100 最后 STDOUT 中按序輸出 1,2,3,4,5…100 我: 我用 Go 實作吧 面試官: 不可以,用 Java 的 notify 機制實作 我:那我用 Java
    BlockingQueue 面試官:說不可以, 要求用 Java 的 wait + notify 機制來實作 我完全沒寫過 wait +
    notify,只能表示不會, 面試官說那行吧你可以用 go 寫 最后用 go channel 實作了一版,
    不過給的網頁上不能運行代碼,也不知道寫得對不對,然后面試結束,

這一輪面試官延續了一面的風格,問完一題就趕忙下一題了,似乎沒有表現出對我的回答有興趣或認可,因此這輪面完,我又覺得自己掛了…

三面

  • 依然先聊專案
  • 對監控警報的專案很感興趣, 問了挺多細節, 最后問了一個問題: 現在要你實作一個語意不弱于 PromQL 的查詢語言, 你能實作嗎?
    這里雖然看過一些 Prometheus 的代碼,但其實對 PromQL 的 lexer 和 parser
    部分沒有細看,還好之前因為資料同步專案里想寫宣告式 Stream SQL 研究過一點 ANTLR,用 ANTLR 寫語法 + AST遍歷塞查詢邏輯給糊弄過去了,
  • 問我覺得做得最深入的專案是什么 當然是資料同步
  • 聊資料同步專案
  • 問 Linux 掌握得怎么樣?
  • 沒有系統學習過,基本上是自己運維踩坑積累的
  • 問 Golang 掌握得怎么樣?
    用了半年, 看過 effective go
  • 問演算法掌握得怎么樣? 到圖為止都可以
  • 問最短路演算法 只記得 dijkstra 了,描述了代碼流程
  • k8s 掌握得怎么樣? 不怎么樣,沒有自己寫過 controller 和 scheduler,但是對概念都很熟悉,看過 xxx 這幾部分的原始碼 k8s 的 exec 是怎么實作的? 這個問題正中下懷,之前寫了 PingCAP 的小作業正好對這塊特別熟悉

這輪聊得順暢多了,同時發現螞蟻的面試官似乎挺喜歡讓你自己評價自己的:“你覺得自己 xxx 掌握得怎么樣?”(只有五位面試官,樣本不夠大,不能作數哦),

四面

  • 介紹一下自己
  • 覺得自己基礎知識掌握怎么樣
  • 平時一般會用到哪些資料結構?
  • 鏈表和陣列相比, 有什么優劣?
  • 如何判斷兩個無環單鏈表有沒有交叉點
  • 如何判斷兩個有環單鏈表有沒有交叉點
  • 如何判斷一個單鏈表有沒有環, 并找出入環點
  • TCP 和 UDP 有什么區別?
  • 描述一下 TCP 四次揮手的程序中
  • TCP 有哪些狀態
  • TCP 的 LISTEN 狀態是什么
  • TCP 的 CLOSE_WAIT 狀態是什么
  • 建立一個 socket 連接要經過哪些步驟
  • 常見的 HTTP 狀態碼有哪些
  • 301和302有什么區別
  • 504和500有什么區別
  • HTTPS 和 HTTP 有什么區別
  • 寫一個演算法題: 手寫快排

這一輪全程問的基礎知識,基礎扎實的話就沒問題了,

五面

  • 介紹一下自己
  • 在 k8s 上做過哪些二次開發?
  • 自己用 Helm 構建過 chart 嗎?有哪些?
  • 有沒有考慮過自己封裝一個面向研發的 PaaS 平臺?
  • 配置中心做了什么?
  • 為什么不用 zookeeper?
  • 配置中心如何保證一致性?
  • Spring 里用了單例 Bean, 怎么保證訪問 Bean 欄位時的并發安全?
  • 用并發安全的資料結構,比如 ConcurrentHashMap;或者加互斥鎖
  • 假如我還想隔離兩個執行緒的資料, 怎么辦?
  • ThreadLocal,然后舉了個例子
  • Golang 里的逃逸分析是什么?怎么避免記憶體逃逸?
  • 這個不知道,認慫了
  • 對比一下 Golang 和 Java 的 GC 答了一下 CMS、G1和三色標記,我對比的點是 JVM 有分代回收,Go 的 Runtime 沒有,沒能深入地講
  • Golang 的 GC 觸發時機是什么 閾值觸發;主動觸發;兩分鐘定時觸發;
  • 有沒有寫過 k8s 的 Operator 或 Controller?(我:沒有寫過)
  • 談一談你對微服務架構的理解 大體思路"微服務本質是人員組織架構演進與關注點分離"
  • 談一談你對 Serveless 的理解 大體思路"Serveless 是繼 docker 與容器編排之后的又一次應用開發與基礎設施提供方之間的邊界劃分"
  • 你認為 Serveless 是未來嗎? 為什么? 大體思路"是云服務的未來,把蛋糕從企業的IT、運維與中間件部門切走,形成規模效應,做得越多賺得越多;公司內的話 servless
    能夠幫助加速前臺業務迭代,但對中后臺的收益還看不到,未來可能會有比 servless 更適合中后臺的架構"
  • 面試官:最后你有什么要問我的? 我:為什么足足安排了五輪技術面,而且其中有兩輪似乎和 k8s 沒有關系啊? 面試官:我們覺得你做過的東西挺多的,各個方向都想讓你嘗試一下 (我的內心:…) 我:那這輪是最后一輪技術面嗎? 面試官:不一定

后續還問了面試官一些業務相關的問題,就不贅述了

六面 HR面

  • 問經歷
  • 為什么要考慮出來看看呢? “現在自己的技術成長有點碰到瓶頸,加上一直對您公司欽慕有加relaxed”"
  • 現在公司的主營業務是什么?(這塊往技術上問了很多,感覺是想考察我解釋復雜問題的能力)
  • 現在帶人嗎?report 層級是怎樣的?
  • 對自己這幾年的經歷滿意嗎?
  • 覺得自己有什么缺點?
  • 碰到過什么很挫敗的事情嗎?
  • 未來的職業規劃是怎樣的?
  • 看機會的時候,主要考慮的是待遇、平臺、人員還是什么其他因素?
  • 現在的待遇如何
  • 有什么想問我的

總結

螞蟻的面試感覺比較注重基礎知識,開發常識,技術見解,沒有偏門和獵奇的問題,基礎知識扎實的同學可以投螞蟻試試,
小編還整理了大廠java程式員面試涉及到的絕大部分面試題及答案免費分享給大家,希望能幫助到大家,有需要的朋友可以看下面的免費領取方式

↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓
領資料點這里:暗號CSDN

在這里插入圖片描述
在這里插入圖片描述

領資料點這里:暗號CSDN
↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑↑

最后感謝大家的支持,希望小編整理的資料能夠幫助到大家!也祝愿大家都能夠升職加薪!
在這里插入圖片描述

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/182609.html

標籤:其他

上一篇:分模塊構建Maven工程

下一篇:吹爆!阿里內部瘋傳:“性能怪獸”Nginx+Redis高階檔案開源分享!

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more