天天看點

一個兩年Java工程師的面試總結(轉載)前言面試整體事項需要準備的知識Java基礎資料結構和算法JVM多線程資料庫相關計算機網絡設計模式分布式相關緩存相關架構相關一些較新的東西一些小建議幾個連結總結

前言

16年畢業到現在也近兩年了,最近面試了阿裡集團(菜鳥網絡,螞蟻金服),網易,滴滴,點我達,最終收到點我達,網易offer,螞蟻金服二面挂掉,菜鳥網絡一個月了還在流程中...

最終有幸去了網易。

但是要特别感謝點我達的上司及HR,真的非常非常好,很感謝他們一直的關照和指導。

面試整體事項

  1. 履歷要準備好,聯系方式一定要正确清晰醒目,項目經曆按照時間倒序闡述,注意描述自己在項目中承擔的職責,履歷的模闆盡量選擇簡潔的,畢竟程式員大部分還是喜歡簡單明了的。
  2. 推薦boss直聘,我覺得很好用(不是廣告)。
  3. 一般的整體面試流程都是電面->現場面->HR面->等着。
  4. 不要覺得HR說讓你回去等消息就是GG了,他們也要跟你之前的面試官讨論,再向上司彙報,如果說不急可能還要和其他候選人比較,是以HR讓你回去等消息絕對不是說明你完蛋了。
  5. 面試前準備好自我介紹,1分鐘左右就可以,可以寫在紙上,電面可以照着念,等你到了現場面了基本也都快背下來你的自我介紹了。
  6. 準備好紮實的基礎,這是一切的根源,沒實力怎麼都沒用的。
  7. 面試中你可以把你的面試官往你會的知識上引導(我遇到過你會什麼他不問什麼的)。
  8. 遇到了設計類題目不要着急,面試官不是為了讓你幾分鐘設計一個高并發高可用設計模式完美的架構,隻是想看看你的思路,看看你應變的能力,然後給你些提示看看你能否迅速的調整。
  9. offer都會有的,不要着急,把面試當成一個交流的過程。

    需要準備的知識

    以下為在近期面試中比較有印象的問題,也就不分公司了,因為沒什麼意義,大緻分類記錄一下,目前隻想起這麼多,不過一定要知道這些問題隻是冰山一角,就算都會了也不能怎麼樣,最最重要的,還是堅實的基礎,清醒的頭腦。

Java基礎

  1. HashMap的源碼,實作原理,JDK8中對HashMap做了怎樣的優化。
  2. HaspMap擴容是怎樣擴容的,為什麼都是2的N次幂的大小。
  3. HashMap,HashTable,ConcurrentHashMap的差別。
  4. 極高并發下HashTable和ConcurrentHashMap哪個性能更好,為什麼,如何實作的。
  5. HashMap在高并發下如果沒有處理線程安全會有怎樣的安全隐患,具體表現是什麼。
  6. java中四種修飾符的限制範圍。
  7. Object類中的方法。
  8. 接口和抽象類的差別,注意JDK8的接口可以有實作。
  9. 動态代理的兩種方式,以及差別。
  10. Java序列化的方式。
  11. 傳值和傳引用的差別,Java是怎麼樣的,有沒有傳值引用。
  12. 一個ArrayList在循環過程中删除,會不會出問題,為什麼。
  13. @transactional注解在什麼情況下會失效,為什麼。

    資料結構和算法

  14. B+樹
  15. 快速排序,堆排序,插入排序(其實八大排序算法都應該了解
  16. 一緻性Hash算法,一緻性Hash算法的應用

    JVM

  17. JVM的記憶體結構。
  18. JVM方法棧的工作過程,方法棧和本地方法棧有什麼差別。
  19. JVM的棧中引用如何和堆中的對象産生關聯。
  20. 可以了解一下逃逸分析技術。
  21. GC的常見算法,CMS以及G1的垃圾回收過程,CMS的各個階段哪兩個是Stop the world的,CMS會不會産生碎片,G1的優勢。
  22. 标記清除和标記整理算法的了解以及優缺點。
  23. eden survivor區的比例,為什麼是這個比例,eden survivor的工作過程。
  24. JVM如何判斷一個對象是否該被GC,可以視為root的都有哪幾種類型。
  25. 強軟弱虛引用的差別以及GC對他們執行怎樣的操作。
  26. Java是否可以GC直接記憶體。
  27. Java類加載的過程。
  28. 雙親委派模型的過程以及優勢。
  29. 常用的JVM調優參數。
  30. dump檔案的分析。
  31. Java有沒有主動觸發GC的方式(沒有)。

    多線程

  32. Java實作多線程有哪幾種方式。
  33. Callable和Future的了解。
  34. 線程池的參數有哪些,線上程池建立一個線程的過程。
  35. volitile關鍵字的作用,原理。
  36. synchronized關鍵字的用法,優缺點。
  37. Lock接口有哪些實作類,使用場景是什麼。
  38. 可重入鎖的用處及實作原理,寫時複制的過程,讀寫鎖,分段鎖(ConcurrentHashMap中的segment)。
  39. 悲觀鎖,樂觀鎖,優缺點,CAS有什麼缺陷,該如何解決。
  40. ABC三個線程如何保證順序執行。
  41. 線程的狀态都有哪些。
  42. sleep和wait的差別。
  43. notify和notifyall的差別。
  44. ThreadLocal的了解,實作原理。

    資料庫相關

  45. 常見的資料庫優化手段
  46. 索引的優缺點,什麼字段上建立索引
  47. 資料庫連接配接池。
  48. durid的常用配置。

    計算機網絡

  49. TCP,UDP差別。
  50. 三次握手,四次揮手,為什麼要四次揮手。
  51. 長連接配接和短連接配接。
  52. 連接配接池适合長連接配接還是短連接配接。

    設計模式

    觀察者模式

    代理模式

    單例模式,有五種寫法,可以參考文章

    單例模式的五種實作方式 可以考Spring中使用了哪些設計模式

    分布式相關

  53. 分布式事務的控制。
  54. 分布式鎖如何設計。
  55. 分布式session如何設計。
  56. dubbo的元件有哪些,各有什麼作用。
  57. zookeeper的負載均衡算法有哪些。
  58. dubbo是如何利用接口就可以通信的。

    緩存相關

  59. redis和memcached的差別。
  60. redis支援哪些資料結構。
  61. redis是單線程的麼,所有的工作都是單線程麼。
  62. redis如何存儲一個String的。
  63. redis的部署方式,主從,叢集。
  64. redis的哨兵模式,一個key值如何在redis叢集中找到存儲在哪裡。
  65. redis持久化政策。

    架構相關

  66. SpringMVC的Controller是如何将參數和前端傳來的資料一一對應的。
  67. Mybatis如何找到指定的Mapper的,如何完成查詢的。
  68. Quartz是如何完成定時任務的。
  69. 自定義注解的實作。
  70. Spring使用了哪些設計模式。
  71. Spring的IOC有什麼優勢。
  72. Spring如何維護它擁有的bean。

    一些較新的東西

  73. JDK8的新特性,流的概念及優勢,為什麼有這種優勢。
  74. 區塊鍊了解
  75. 如何設計雙11交易總額面闆,要做到高并發高可用。

    一些小建議

  76. 可以去leetcode上刷題換換思路。
  77. 八大排序算法一定要手敲一遍(快排,堆排尤其重要)。
  78. 了解一些新興的技術。
  79. 面試之後面試官都會問你有沒有什麼問題,千萬不要沒問題,也别傻乎乎的問一些敏感問題。
  80. 了解你要面試的公司的産品及競争産品。

    幾個連結

    很多Java面試題 更多Java面試題 還是Java面試題

    總結

    無論是哪家公司,都很重視高并發高可用的技術,重視基礎,重視JVM。面試是一個雙向選擇的過程,不要抱着畏懼的心态去面試,不利于自己的發揮。同時看中的應該不止薪資,還要看你是不是真的喜歡這家公司,是不是能真的得到鍛煉。其實我寫了這麼多,隻是我自己的總結,并不一定适用于所有人,相信經過一些面試,大家都會有這些感觸。

    如果這些文字能夠幫到你,那就最好了,幫不到就當是我自己的一個記錄。

    最後,希望大家都能找到适合自己的公司,開開心心的撸代碼~

作者:vipwhr

原文連結:

https://jq.qq.com/?_wv=1027&k=50lAcZb https://segmentfault.com/a/1190000013550405