剛從今日頭條Java研發崗面試回來,我總結的失敗原因(附面試題)

面試崗位:
後端研發工程師
找牛客大佬要了白金碼,跳過死亡筆試,直接視訊面,從3點開始,到晚上8點結束。
每個面試官給我的感覺都是怎麼這麼高冷啊。
一面:
寫一個題,找一個無序陣列的中位數
寫了個快排,然後讓我找到無序陣列第k大的一個數,我說先排序再找,實際上可以用快排的partition函式。
快排的時間複雜度,最壞情況呢,最好情況呢,堆排序的時間複雜度呢,建堆的複雜度是多少,nlgn。
作業系統瞭解麼,Linux和windows
說說Linux的磁碟管理,一臉懵逼
Linux有哪些程序通訊方式,五大件
Linux的共享記憶體如何實現,大概說了一下。
共享記憶體實現的具體步驟,我說沒用過
socket網路程式設計,說一下TCP的三次握手和四次揮手,中間網路不好,面試官都沒聽清楚,很尷尬
跳過網路,問了專案的一些東西
問我如何把docker講的很清楚,我從物理機,虛擬機器到容器具體實現稍微說了下。
問我cgroup在linux的具體實現,不會。
多執行緒用過哪些,chm和countdownlatch用過
二面:
自我介紹
Java的集合類哪些是執行緒安全
分別說說這些集合類,hashmap怎麼實現的,扯了很多
MySQL索引的實現,innodb的索引,b+樹索引是怎麼實現的,為什麼用b+樹做索引節點,一個節點存了多少資料,怎麼規定大小,與磁碟頁對應。
MySQL的事務隔離級別,分別解決什麼問題。
Redis瞭解麼,如果Redis有1億個key,使用keys命令是否會影響線上服務,我說會,因為是單執行緒模型,可以部署多個節點。
問我知不知道有一條命令可以實現上面這個功能。不知道
Redis的持久化方式,aod和rdb,具體怎麼實現,追加日誌和備份檔案,底層實現原理的話知道麼,不清楚。
Redis的list是怎麼實現的,我說用ziplist+quicklist實現的,ziplist壓縮空間,quicklist實現連結串列。
sortedset怎麼實現的,使用dict+skiplist實現的,問我skiplist的資料結構,大概說了下是個實現簡單的快速查詢結構。
瞭解什麼訊息佇列,rmq和kafka,沒細問
寫題時間到。第一題:寫一個層序遍歷。
第二題:寫一個插入樹節點到一顆排序樹的插入方法,使用遞迴方式找到插入位置即可。
第三題:一個有向圖用鄰接矩陣表示,並且是有權圖,現在問怎麼判斷圖中有沒有環。
我說直接dfs走到原點即為有環,剛開始寫的時候我又問了一嘴是不是隻要找到一個就行,面試官說是的,然後我說這樣應該用bfs,有一次訪問到原節點就是有環了。
面試官問我不用遞迴能不能做這個題,其實我都還沒開始寫。然後我就說沒有思路,他提示我拓撲圖。我沒明白拓撲圖能帶來什麼好處。現在一想,好像當訪問過程中找不到下一個節點時就說明有環。做一個訪問標記應該就可以。
第四題:一個二叉樹,找到二叉樹中最長的一條路徑。
我先用求樹高的方式求出了根節點的左右子樹高度,加起來便是。
然後面試官提示需要考慮某個子樹深度特別大的情況,於是我用遍歷的方式重新整理最大值,用上面那個方法遍歷完整個樹即可。
面試官說複雜度比較高,但是由於時間問題就說結束了。
三面:
介紹一下專案
你談到的併發技術,chm和countdownlatch怎麼使用的
為什麼要這麼處理,使用執行緒池是不是也可以。我說也可以
作業系統的程序通訊方式,殭屍程序和孤兒程序是什麼,如何避免殭屍程序,我說讓父程序顯示通知,那父程序怎麼知道子程序結束了,答不會。
計算機網路TCP和UDP有什麼區別,為什麼迅雷下載是基於UDP的,我說FTP是基於TCP,而迅雷是p2p不需要TCP那麼可靠的傳輸保證。
作業系統的死鎖必要條件,如何避免死鎖。
寫一個LRU的快取,需要完成超時淘汰和LRU淘汰。
我說用lhm行不行,他說用linkedlist和hashmap可以。
於是我就寫了put和get函式,進行了隊頭隊尾操作。
他說get複雜度會不會太高,我瞎掰了半天沒找到辦法,他說那就這樣吧,今天面試到這。
過期淘汰的處理我還沒寫呢,就說結束了,感覺涼了啊,我說我要不要把剩下邏輯下完,他說不用,心涼了一大截~
然後HR小姐姐讓我等結果了。
面試經歷只是提供給大家一點臨時的應付技巧,真正的本領還是要靠平時的學習和積累, 只有學習的多了,技術掌握的透徹, 才會在面試的時候臨危不亂,處變不驚。臨時抱佛腳雖然有時可行,但是,也有抱不住的時候啊。
因此在這裡也給那些技術想達到這個高度甚至想往架構師發展的Java程式設計師提供一份詳細的進階路線圖,主要針對2到5年及以上工作經驗的Java開發人員,從廣度到深度架構圖還比較全面的,裡面的技術包涵了Java高併發、微服務、原始碼分析、原始碼分析、高效能、分散式等技術,這些也是目前網際網路企業比較常用的技術,那麼來詳細看看。 (文末有高清完整樹圖領取)
1.原始碼分析

2.分散式專題

3.微服務專題

4.效能優化

裡面包含的技術不是讓你全部掌握,但是很多東西是面試官必問的,所以你不能不知道,希望給那些需要這些資訊的人幫助。
最後
以上就是筆者分享進階架構師學習線路 ,分享了一波進階線路圖譜,那麼資源肯定也是少不了的,如果你對技術提升很感興趣,小編在這裡提供了一份針對上面導圖的架構進階視訊資料,資源分享包括但不限於(分散式架構、高可擴充套件、高效能、高並 發、Jvm效能調優、Spring,MyBatis,Nginx原始碼分析,Redis,ActiveMQ、、Mycat、Netty、Kafka、Mysql 、Zookeeper、Tomcat、Docker、Dubbo、Nginx)。
資料獲取方式:加QQ群:935692859 進群免費領取資料!
點選連結加入群聊【Java架構交流二群】: 點選進群

