各大網際網路Java面試題彙總,最後我成功拿到百度的offer(文末送書)
從事Java開發也有5年經驗了,7月初來到帝都,開啟面試經歷,前後20天左右,主要面網際網路公司,一二線大公司或者是融資中的創業公司都面試過,拿了一些offer,其中包括奇虎360,最後綜合決定還是去百度了。
首先不同面試官面試風格一定不同,我這裡就是總結這些天面試Java開發過程中的大多數問題,綜合分類有Java基礎,框架,多執行緒,網路通訊,資料庫以及設計模式,等幾個模組,由於問題太多,下面先列出問題,之後有時間在寫文章解答,或者網上有很多答案,可以自行搜尋。
關於專業技能
寫完專案接著寫一名3年工作經驗的Java程式設計師應該具備的技能,這可能是Java程式設計師們比較關心的內容。我這裡要說明一下,以下列舉的內容不是都要會的東西----但是如果你掌握得越多,最終能得到的評價、拿到的薪水勢必也越高。
1.String類為什麼是final的。
2.HashMap的原始碼,實現原理,底層結構。
3.反射中,Class.forName和classloader的區別
4.session和cookie的區別和聯絡,session的生命週期,多個服務部署時session管理。
5.Java中的佇列都有哪些,有什麼區別。
6.Java的記憶體模型以及GC演算法
7.Java7、Java8的新特性(baidu問的,好BT)
8.Java陣列和連結串列兩種結構的操作效率,在哪些情況下(從開頭開始,從結尾開始,從中間開始),哪些操作(插入,查詢,刪除)的效率高
9.Java記憶體洩露的問題調查定位:jmap,jstack的使用等等
這也是必問的一塊了。因為三年工作經驗,所以基本上不會再問你怎麼實現多執行緒了,會問得深入一些比如說Thread和Runnable的區別和聯絡、多次start一個執行緒會怎麼樣、執行緒有哪些狀態。當然這只是最基本的,出乎意料地,幾次面試幾乎都被同時問到了一個問題,問法不盡相同,總結起來是這麼一個意思:
假如有Thread1、Thread2、Thread3、Thread4四條執行緒分別統計C、D、E、F四個盤的大小,所有執行緒都統計完畢交給Thread5執行緒去做彙總,應當如何實現?
聰明的網友們對這個問題是否有答案呢?不難,java.util.concurrent下就有現成的類可以使用。
另外,執行緒池也是比較常問的一塊,常用的執行緒池有幾種?這幾種執行緒池之間有什麼區別和聯絡?執行緒池的實現原理是怎麼樣的?實際一些的,會給你一些具體的場景,讓你回答這種場景該使用什麼樣的執行緒池比較合適。
最後,雖然這次面試問得不多,但是多執行緒同步、鎖這塊也是重點。
synchronized和ReentrantLock的區別、synchronized鎖普通方法和鎖靜態方法、死鎖的原理及排查方法等等,關於多執行緒,我在之前有些過文章總結過多執行緒的40個問題,可以參看40個Java多執行緒問題總結。
三、IO再次補充IO的內容,之前忘了寫了。
IO分為File IO和Socket IO,File IO基本上是不會問的,問也問不出什麼來,平時會用就好了,另外記得File IO都是阻塞IO。
Socket IO是比較重要的一塊,要搞懂的是阻塞/非阻塞的區別、同步/非同步的區別,藉此理解阻塞IO、非阻塞IO、多路複用IO、非同步IO這四種IO模型,Socket IO如何和這四種模型相關聯。這是基本一些的,深入一些的話,就會問NIO的原理、NIO屬於哪種IO模型、NIO的三大組成等等,這有些難,當時我也是研究了很久才搞懂NIO。提一句,NIO並不是嚴格意義上的非阻塞IO而應該屬於多路複用IO,面試回答的時候要注意這個細節,講到NIO會阻塞在Selector的select方法上會增加面試官對你的好感。
如果用過Netty,可能會問一些Netty的東西,畢竟這個框架基本屬於當前最好的NIO框架了(Mina其實也不錯,不過總體來說還是比不上Netty的),大多數網際網路公司也都在用Netty。
四、JDK原始碼要想拿高工資,JDK原始碼就不可不讀。上面的內容可能還和具體場景聯絡起來,JDK原始碼就是實打實地看你平時是不是愛鑽研了。過程中被問了不少JDK原始碼的問題,其中最刁鑽的一個問了,String的hashCode()方法是怎麼實現的,幸好平時String原始碼看得多,答了個大概。JDK原始碼其實沒什麼好總結的,純粹看個人,總結一下比較重要的原始碼:
(1)List、Map、Set實現類的原始碼
(2)ReentrantLock、AQS的原始碼
(3)AtomicInteger的實現原理,主要能說清楚CAS機制並且AtomicInteger是如何利用CAS機制實現的
(4)執行緒池的實現原理
(5)Object類中的方法以及每個方法的作用
這些其實要求蠻高的,去年一整年基本把JDK中重要類的原始碼研究了個遍,真的花費時間、花費精力,當然回頭看,是值得的----不僅僅是為了應付面試。
五、框架1.struts1和struts2的區別
2.struts2和springMVC的區別
3.spring框架中需要引用哪些jar包,以及這些jar包的用途
4.srpingMVC的原理
5.springMVC註解的意思
6.spring中beanFactory和ApplicationContext的聯絡和區別
7.spring注入的幾種方式
8.spring如何實現事務管理的
9.springIOC和AOP的原理
10.hibernate中的1級和2級快取的使用方式以及區別原理
11.spring中迴圈注入的方式
六、資料庫資料庫十有八九也都會問到。一些基本的像union和union all的區別、left join、幾種索引及其區別就不談了,比較重要的就是資料庫效能的優化,如果對於資料庫的效能優化一竅不通,那麼有時間,還是建議你在面試前花一兩天專門把SQL基礎和SQL優化的內容準備一下。
不過資料庫倒是不用擔心,一家公司往往有很多部門,如果你對資料庫不熟悉而基本技術又非常好,九成都是會要你的,估計會先把你放到對資料庫使用不是要求非常高的部門鍛鍊一下。
七、資料結構與演算法資料結構和演算法分析,對於一名程式設計師來說,會比不會好而且在工作中絕對能派上用場。陣列、連結串列是基礎,棧和佇列深入一些但也不難,樹挺重要的,比較重要的樹AVL樹、紅黑樹,可以不瞭解它們的具體實現,但是要知道什麼是二叉查詢樹、什麼是平衡樹,AVL樹和紅黑樹的區別。記得某次面試,某個面試官和我聊到了資料庫的索引,他問我:
你知道索引使用的是哪種資料結構實現嗎?
答到用的Hash表吧,答錯。他又問,你知道為什麼要使用樹嗎?答到因為Hash表可能會出現比較多的衝突,在千萬甚至是上億級別的資料面前,會大大增加查詢的時間複雜度。而樹比較穩定,基本保證最多二三十次就能找到想要的資料,對方說不完全對,最後我們還是交流了一下這個問題,我也明白了為什麼要使用樹,這裡不說,網友朋友們覺得索引為什麼要使用樹來實現呢?
八、Java虛擬機器出乎意料,Java虛擬機器應該是很重要的一塊內容,結果在這幾家公司中被問到的概率幾乎為0。要知道,去年可是花了大量的時間去研究Java虛擬機器的,《深入理解Java虛擬機器:JVM高階特性與最佳實踐》,就讀了不下五遍。
言歸正傳,雖然Java虛擬機器沒問到,但我覺得還是有必要研究的,就簡單地列一個提綱吧,談談Java虛擬機器中比較重要的內容:
(1)Java虛擬機器的記憶體佈局
(2)GC演算法及幾種垃圾收集器
(3)類載入機制,也就是雙親委派模型
(4)Java記憶體模型
(5)happens-before規則
(6)volatile關鍵字使用規則
經過幾輪面試,雖然很多沒有記住,自己最後簡單的整理了一下,把這些網際網路面試題分享給大家,其實一線網際網路公司並沒有那麼的神祕,也沒有想象中那麼難進,程式設計師是吃技術飯,要養成堅持學習的習慣,最後我在網上找了一些關於回答面試題的,也有一些Java高併發、分散式、高效能、微服務等架構技術資料,一併給大家分享在我的Java後端技術群裡面,歡迎大家來下載。
人到中年,開始走下坡路,擔心被前浪拍在沙灘上,被“下崗”、或者“提前下崗”簡直是嚇得瑟瑟發抖啊!
為了幫大家擺脫這種中年危機,走上升職加薪的道路。
給大家推薦一個我朋友的Java架構技術公眾號,裡面會分享分散式、微服務、高併發、JVM,以及大資料,區塊鏈等技術文章,會不定時分享IT類最新資訊。
成就夢想不是夢,還是要看你關注不關注!
技術在手,offer我有
關注上方公眾號,從當日新增粉絲中抽取3名幸運粉絲各贈送一本
:微服務(Spring Cloud)的書給大家,郵費我出!!!)