前言
15年畢業到現在也近三年了,最近面試了阿里集團(菜鳥網絡,螞蟻金服),網易,滴滴,點我達,最終收到點我達,網易offer,螞蟻金服二面掛掉,菜鳥網絡一個月了還在流程中...
最終有幸去了網易。
但是要特別感謝點我達的領導及HR,真的非常非常好,很感謝他們一直的關照和指導。
面試整體事項
- 簡歷要準備好,聯繫方式一定要正確清晰醒目,項目經歷按照時間倒序闡述,注意描述自己在項目中承擔的職責,簡歷的模板儘量選擇簡潔的,畢竟程序員大部分還是喜歡簡單明瞭的。
- 推薦boss直聘,我覺得很好用(不是廣告)。
- 一般的整體面試流程都是電面->現場面->HR面->等着。
- 不要覺得HR說讓你回去等消息就是GG了,他們也要跟你之前的面試官討論,再向領導彙報,如果說不急可能還要和其他候選人比較,所以HR讓你回去等消息絕對不是說明你完蛋了。
- 面試前準備好自我介紹,1分鐘左右就可以,可以寫在紙上,電面可以照着念,等你到了現場面了基本也都快背下來你的自我介紹了。
- 準備好紮實的基礎,這是一切的根源,沒實力怎麼都沒用的。
- 面試中你可以把你的面試官往你會的知識上引導(我遇到過你會什麼他不問什麼的)。
- 遇到了設計類題目不要着急,面試官不是爲了讓你幾分鐘設計一個高併發高可用設計模式完美的架構,只是- 想看看你的思路,看看你應變的能力,然後給你些提示看看你能否迅速的調整。
- offer都會有的,不要着急,把面試當成一個交流的過程。
###需要準備的知識
以下爲在近期面試中比較有印象的問題,也就不分公司了,因爲沒什麼意義,大致分類記錄一下,目前只想起這麼多,不過一定要知道這些問題只是冰山一角,就算都會了也不能怎麼樣,最最重要的,還是堅實的基礎,清醒的頭腦。
Java基礎
- HashMap的源碼,實現原理,JDK8中對HashMap做了怎樣的優化。
- HaspMap擴容是怎樣擴容的,爲什麼都是2的N次冪的大小。
- HashMap,HashTable,ConcurrentHashMap的區別。
- 極高併發下HashTable和ConcurrentHashMap哪個性能更好,爲什麼,如何實現的。
- HashMap在高併發下如果沒有處理線程安全會有怎樣的安全隱患,具體表現是什麼。
- java中四種修飾符的限制範圍。
- Object類中的方法。
- 接口和抽象類的區別,注意JDK8的接口可以有實現。
- 動態代理的兩種方式,以及區別。
- Java序列化的方式。
- 傳值和傳引用的區別,Java是怎麼樣的,有沒有傳值引用。
- 一個ArrayList在循環過程中刪除,會不會出問題,爲什麼。
- @transactional註解在什麼情況下會失效,爲什麼。
數據結構和算法
- B+樹
- 快速排序,堆排序,插入排序(其實八大排序算法都應該瞭解
- 一致性Hash算法,一致性Hash算法的應用
JVM
- JVM的內存結構。
- JVM方法棧的工作過程,方法棧和本地方法棧有什麼區別。
- JVM的棧中引用如何和堆中的對象產生關聯。
- 可以瞭解一下逃逸分析技術。
- GC的常見算法,CMS以及G1的垃圾回收過程,CMS的各個階段哪兩個是Stop the world的,CMS會不會產生碎片,G1的優勢。
- 標記清除和標記整理算法的理解以及優缺點。
- eden survivor區的比例,爲什麼是這個比例,eden survivor的工作過程。
- JVM如何判斷一個對象是否該被GC,可以視爲root的都有哪幾種類型。
- 強軟弱虛引用的區別以及GC對他們執行怎樣的操作。
- Java是否可以GC直接內存。
- Java類加載的過程。
- 雙親委派模型的過程以及優勢。
- 常用的JVM調優參數。
- dump文件的分析。
- Java有沒有主動觸發GC的方式(沒有)。
多線程
- Java實現多線程有哪幾種方式。
- Callable和Future的瞭解。
- 線程池的參數有哪些,在線程池創建一個線程的過程。
- volitile關鍵字的作用,原理。
- synchronized關鍵字的用法,優缺點。
- Lock接口有哪些實現類,使用場景是什麼。
- 可重入鎖的用處及實現原理,寫時複製的過程,讀寫鎖,分段鎖(ConcurrentHashMap中的segment)。
- 悲觀鎖,樂觀鎖,優缺點,CAS有什麼缺陷,該如何解決。
- ABC三個線程如何保證順序執行。
- 線程的狀態都有哪些。
- sleep和wait的區別。
- notify和notifyall的區別。
- ThreadLocal的瞭解,實現原理。
數據庫相關
- 常見的數據庫優化手段
- 索引的優缺點,什麼字段上建立索引
- 數據庫連接池。
- durid的常用配置。
計算機網絡
- TCP,UDP區別。
- 三次握手,四次揮手,爲什麼要四次揮手。
- 長連接和短連接。
- 連接池適合長連接還是短連接。
設計模式
- 觀察者模式
- 代理模式
- 單例模式,有五種寫法,可以參考文章單例模式的五種實現方式
- 可以考Spring中使用了哪些設計模式
分佈式相關
- 分佈式事務的控制。
- 分佈式鎖如何設計。
- 分佈式session如何設計。
- dubbo的組件有哪些,各有什麼作用。
- zookeeper的負載均衡算法有哪些。
- dubbo是如何利用接口就可以通信的。
緩存相關
- redis和memcached的區別。
- redis支持哪些數據結構。
- redis是單線程的麼,所有的工作都是單線程麼。
- redis如何存儲一個String的。
- redis的部署方式,主從,集羣。
- redis的哨兵模式,一個key值如何在redis集羣中找到存儲在哪裏。
- redis持久化策略。
框架相關
- SpringMVC的Controller是如何將參數和前端傳來的數據一一對應的。
- Mybatis如何找到指定的Mapper的,如何完成查詢的。
- Quartz是如何完成定時任務的。
- 自定義註解的實現。
- Spring使用了哪些設計模式。
- Spring的IOC有什麼優勢。
- Spring如何維護它擁有的bean。
- 一些較新的東西
- JDK8的新特性,流的概念及優勢,爲什麼有這種優勢。
- 區塊鏈瞭解
- 如何設計雙11交易總額面板,要做到高併發高可用。
一些小建議
- 可以去leetcode上刷題換換思路。
- 八大排序算法一定要手敲一遍(快排,堆排尤其重要)。
- 瞭解一些新興的技術。
- 面試之後面試官都會問你有沒有什麼問題,千萬不要沒問題,也別傻乎乎的問一些敏感問題。
- 瞭解你要面試的公司的產品及競爭產品。
總結
無論是哪家公司,都很重視高併發高可用的技術,重視基礎,重視JVM。面試是一個雙向選擇的過程,不要抱着畏懼的心態去面試,不利於自己的發揮。同時看中的應該不止薪資,還要看你是不是真的喜歡這家公司,是不是能真的得到鍛鍊。其實我寫了這麼多,只是我自己的總結,並不一定適用於所有人,相信經過一些面試,大家都會有這些感觸。
如果這些文字能夠幫到你,那就最好了,幫不到就當是我自己的一個記錄。
讀者福利(學習分享)
對於很多初級Java工程師而言,想要提升技能,往往是自己摸索成長,不成體系的學習效果低效漫長且無助。
整理的這些架構技術希望對Java開發的朋友們有所參考以及少走彎路,本文的重點是你有沒有收穫與成長,其餘的都不重要,希望讀者們能謹記這一點。同時歡迎工作一到五年的Java工程師朋友們加入Java進階學習交流:868284384
羣內提供免費的Java架構學習資料(裏面有高可用、高併發、高性能及分佈式、Jvm性能調優、Spring源碼,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多個知識點的架構資料)合理利用自己每一分每一秒的時間來學習提升自己,不要再用"沒有時間“來掩飾自己思想上的懶惰!趁年輕,使勁拼,給未來的自己一個交代!
在分享一個學習資源筆記分享給大家:Java架構進階學習資源分享