技術一面20分鐘
1、自我介紹
說了很多遍了,很流暢撿重點介紹完,
2、問我資料結構演算法好不好
挺好的(其實心還是有點虛,不過最近刷了很多題也只能壯著膽子充胖子了)
3、找到單鏈表的三等分點,如果單鏈表是有環的呢
用快慢指標,一個走一步,一個走三步,如果有環,先判斷環在哪,找最后一個節點,然后用之前的無環的做法
4、講一下專案的架構
我重點講了MVC
5、說一下你熟悉的設計模式
我重點講了單例、工廠方法、代理
5、有沒有配置過服務器啥啥啥
這個我真不知道,都沒聽過呢,只能誠實說沒有,畢竟都沒法扯,
一面挺匆忙的,我估計面試官剛開完會還沒吃飯呢,他說讓我等,可能再找一個同事面我,可能就直接告訴我結果了,從一面面試官的聲音和口吻,我判斷他一定是個部門老大,問的設計偏多,后面hr告訴我他就是我要去的部門的老大,哈哈,
技術二面60分鐘,詳細問答
1、Spring:有沒有用過Spring,Spring IOC、AOP機制與實作,Spring MVC
其實我挺不想被問到Spring的細節的,框架這些我都沒有復習不太記得了,所以我對面試官說Spring里面的一些比較重要的機制我理解的還不錯,然后我用一個實際的例子把我對IOC、AOP理解講了一下,他聽了說對,理解的不錯(難得遇到一個邊面試邊能給反饋的面試官,好開心)
Spring MVC其實我用過,我就對面試官講了我的專案中用到的Servlet,jsp和javabean實作的MVC,以及MVC各個模塊職責以及每個模塊是怎么聯系到一起的,最后我補充了一句我想SpringMVC的思想其實跟這個是一樣的(他說對的,嘿嘿有反饋真好)
2、多執行緒:怎么實作執行緒安全,各個實作方法有什么區別,volatile關鍵字的使用,可重入鎖的理解,Synchronized是不是可重入鎖
這里我就主要講了Synchronized關鍵字,還有并發包下面的一些鎖,以及各自的優缺點和區別,volatile關鍵字我主要從可見性、原子性和禁止JVM指令重排序三個方面講的,再講了一下我在多執行緒的單例模式double-check中用到volatile關鍵字禁止JVM指令重排優化,
3、集合: HashMap底層實作,怎么實作HashMap執行緒安全
我講了一下HashMap底層是陣列加單鏈表實作,Node內部類,add的程序,Hash沖突解決辦法,擴容,三種集合視圖,HashMap執行緒安全的實作方式主要講了HashTable、ConcurrentHashMap以及Collections中的靜態方法SynchronizedMap可以對HashMap進行封裝,以及這三種方式的區別,效率表現,
4、JVM記憶體管理,GC演算法,HotSpot里面的垃圾回收器、類加載
JVM記憶體主要分為五個區,哪些是執行緒共享的,哪些是執行緒獨享的,每個區存放什么,GC方面:怎么判斷哪些物件需要被GC,GC的方法,Minor GC與Full GC,HotSpot GC演算法以及7種垃圾回收期,主要講了CMS和G1收集器,類加載:類加載的程序,Bootstrap classloader-ExtClassloader-AppClassloader,父類委托機制,
5、行程和執行緒的區別
從調度、并發性、擁有的資源和系統開銷四個方面回答的,
6、HTTP有沒有狀態,我說無狀態,怎么解決HTTP無狀態 怎么解決HTTP無狀態其實就是怎么進行會話跟蹤,有四種方法:URL重寫、隱藏表單域、Cookie、Session,
7、Java IO,NIO,Java中有沒有實作異步IO
Java IO實作的是同步阻塞,它是怎么實作同步阻塞的,我拿了read()方法舉例來講的,NIO實作的是同步非阻塞,我詳細講了一下Selector中的select()方法輪詢說明它是如何實作多路復用IO的,然后對比了一下他們的效率,面試官可能看我對這一塊比較了解,又繼續問我Java中有沒有實作異步IO,我感覺好像沒有,但面試官說有,讓我想想,其實這里我并不清楚啦,所以我就對面試官講了一下我對Unix中異步IO模型的理解,然后說至于Java里面有沒有我真的不太清楚,(他居然笑了!說你理解是對的,Java里面有沒有不重要!哈哈)
8、前端會不會,Ajax是什么,Ajax實作原理
前端我只是會用一些js而已,用過jquery框架,問我Ajax全稱是啥,我猜是異步的js和xml,Ajax實作原理其實我也不懂,我就只簡單講了一下它通過XMLHttpRequest物件進行異步查詢,Ajax引擎在客戶端運行,減少了服務器作業量,
9、讓我設計一個執行緒池
因為我簡歷中有寫到我對多執行緒、并發這一塊理解比較好,所以他老問這方面的題,這個問題因為我之前看過ThreadPoolExecutor的源代碼,所以我就仿照那個類的設計思路來想的,詳細講了一下核心池、創建執行緒可以用工廠方法模式來進行設計、執行緒池狀態、阻塞佇列、拒絕策略這幾個方面,設計的還算比較周全,
10、講幾個設計模式,哪些地方用到了,為什么要用
單例模式,jdk中的getRuntime();工廠方法模式,ThreadPoolExcutor用到ThreadFactory;觀察者模式:java.util包下面的Observable和Observer,最后主要講了一下工廠方法模式的使用場景,
11、Mysql優化、索引的實作
我從資料庫設計優化和查詢優化兩方面講的,索引B+樹實作,InnoDB和MyISAM主鍵索引的實作區別,一個聚集一個非聚集,
12、事務的隔離級別
四種隔離級別,可能會出現哪些例外,mysql中默認級別,
13、有沒有用過Hibernate、mybatis、git
這個簡單講一下就好,分別是干什么的
*14、Linux *
我說這個本科學過,但是很久沒用,命令忘光了,他說沒事,考你幾個簡單的:cd、ls、dir(真的是簡單的)
15、演算法題
從10萬個數中找最小的10個,時間復雜度分析(最大堆,考慮記憶體)
從一個有正有負陣列中找連續子陣列的最大和,時間復雜度分析(動態規劃)
滿二叉樹第i層有多少個節點,n層的滿二叉樹共有多少個節點
終于到我提問環節了
1、你們是什么部門(他說是核心部門,大資料研發)
2、我對高并發和負載均衡挺有興趣的,但是我平時在學校也沒有這個環境讓我在這方面有所體驗,那你建議我目前可以怎么學呢(他說這確實是不太好學,只能看些理論和別人的博客,以后作業中才能慢慢學)
3、中間件具體是做什么的,是解決高并發和負載均衡嗎(他說差不多是的,然后他說我們這個部門不是中間件,是大資料部門啊,我說恩我知道)
最后沒啥問題了,他讓我保持電話暢通,
技術三面25分鐘
面試官說是他是另外一個部門的,需要進行交叉面試,
1、MySql優化
2、說下專案做了些什么,架構之類的
3、在collabedit上在線寫代碼,題目很簡單是編程之美上的原題,一個有序的整數陣列,輸出兩個數,使它們的和為某個給定的值,之前做過很快寫好,然后給他講思路,他繼續問如果陣列無序怎么辦,先排序,
4、兩個檔案,每個檔案中都有若干個url,找出兩個檔案中相同的url(用HashMap)
這一面挺簡單的,只是增加之前面試沒有過的在線寫代碼環節,collabedit后來我才了解,像facebook一些互聯網公司遠程面試都會用這個在線編輯器寫代碼,就是文本檔案寫,沒有提示,不能編譯運行,跟白板寫一樣,平時練練手就好,
技術HR四面30分鐘
三面面試官說他那就是終面,說我過了等hr聯系我,萬萬沒想到半小時后的hr面居然也是技術,
1、自我介紹,都四面了還自我介紹?!我還以為是單純的hr面,所以介紹的都是我的性格和生活方面的,結果并不是,
2、問專案,問的特別特別細,技術細節,還有遇到什么問題,怎么解決的,做專案有沒有人帶,怎么跟別人溝通的,
3、資料庫優化,如果資料庫一個表特別大怎么辦 資料庫優化我就講了之前講過很多遍的點,他問一個表特別大怎么辦:大表分小表,怎么實作:使用磁區表
總結
- 怎樣才能拿到大廠的offer,沒有掌握絕對的技術,那么就要不斷的學習
- 面試:如果不準備充分的面試,完全是浪費時間,更是對自己的不負責,
下面是我整理的2020年大廠經常問到的一些面試真題及決議以及大廠面試場景,有想獲取到參考借鑒的朋友可以幫忙點贊后,私信【面試】就可以了(一定要記得關注我,不然沒辦法回復陌生人私信)希望大家都能夠拿到一個心怡的offer,
面試題及決議:內容點包含有java集合,jvm,并發編程,spring,mybatis,springMVC,微服務,Dubbo,netty,網路,zookeeper,kafka,rabbitMQ,readis快取,資料庫,設計模式 等一線大廠互聯網大廠常問到的面試真題


大廠面試場景

轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/170687.html
標籤:其他
下一篇:十年電商大廠面試官總結100道大廠高頻面試題:Dubbo,ElasticSearch,JVM,多執行緒/高并發,訊息中間件
