工作5年的阿里Java程式設計師分享從業心得總結與面試筆記分享

程式設計師小天發表於2020-10-29

工作第一年,往往是什麼都充滿新鮮感,什麼都學習,衝勁十足的一年;WEB行業知識更新特別快,今天一個框架的新版本,明天又是另一個新框架,有時往往根據專案的需要來不斷學習新東西;所有,很多時候感覺,自己用過的東西真多呀!但是真正深入研究的東西卻不多。面試,是跳槽後第一個需要面對的問題;而且不同公司面試的著重點不同;但是卻有一個共同點:Java基礎是必考的。

工作第一年,可能問你String物件建立的理解,常用的框架是什麼等等;
工作第三年,就問你Java記憶體分配機制是什麼,類是如何載入的等等;
工作第五年,就問你常用的設計模式是什麼,你在工作中充當什麼角色,怎麼獨立完成一個模組等等;
可以看出——這是一個典型的程式設計師的成長過程:

最新2020整理收集的一些面試題(都整理成文件),有很多幹貨,涵蓋了阿里巴巴、騰訊、位元組跳動、京東、華為等大廠的Java面試真題,不管你是要面試大廠還是普通的網際網路公司,這些面試題對你肯定是有幫助的,畢竟大廠一定是行業的發展方向標杆,很多公司的面試官同樣會研究大廠的面試題。也有詳細的學習規劃圖,

獲取面試資料只需:點選這裡領取!!! 暗號:CSDN。

Java基礎

1.JAVA 中的幾種資料型別是什麼,各自佔用多少位元組。

2.String 類能被繼承嗎,為什麼。

3. 兩個物件的 hashCode() 相同,則 equals() 也一定為 true,對嗎?

4. String 屬於基礎的資料型別嗎?

5.Java 中操作字串都有哪些類?它們之間有什麼區別?

6.Java 中 IO 流分為幾種?

7.BIO、NIO、AIO 有什麼區別?

8.用過哪些 Map 類,都有什麼區別,HashMap 時執行緒安全的嗎,併發下使用的 Map 是什麼,他們的內部原理分別是什麼,比如儲存方法,hashcode,擴容,預設容量等。

9. 如何將字串反轉?

10.抽象類必須要有抽象方法嗎?

11.普通類和抽象類有哪些區別?

12.抽象類能使用 final 修飾嗎?

13.ArrayList 和 LinkedList 有什麼區別?

14.ConcurrentHashMap的資料結構(必考)

15.volatile作用(必考)

16.Atomic類如何保證原子性(CAS操作)(必考)

17.為什麼要使用執行緒池(必考)

image

Redis

  • Redis的應用場景
  • Redis支援的資料型別(必考)
  • zset跳錶的資料結構(必考)
  • Redis的資料過期策略(必考)
  • Redis的LRU過期策略的具體實現
  • 如何解決Redis快取雪崩,快取穿透問題
  • Redis的持久化機制(必考)
  • Redis為什麼是單執行緒的?
  • 什麼是快取穿透?怎麼解決?
  • Redis持久化有幾種方式?
  • Redis為什麼這麼快?(必考)
  • Redis怎麼實現分散式鎖?
  • Redis如何做記憶體優化?
  • Redis淘汰策略有哪些?
  • Redis常見的效能問題有哪些?該如何解決?
  • Redis的使用要注意什麼?

image

ZooKeeper

  • CAP定理
  • ZAB協議
  • leader選舉演算法和流程
  • zookeeper 是什麼?
  • zookeeper 有幾種部署模式?
  • zookeeper 怎麼保證主從節點的狀態同步?

image

Mysql

  • 事務的基本要素
  • 事務隔離級別(必考)
  • 如何解決事務的併發問題(髒讀,幻讀)(必考)
  • MVCC多版本併發控制(必考)
  • binlog,redolog,undolog都是什麼,起什麼作用
  • InnoDB的行鎖/表鎖
  • myisam和innodb的區別,什麼時候選擇myisam
  • 為什麼選擇B+樹作為索引結構(必考)
  • 索引B+樹的葉子節點都可以存哪些東西(必考)
  • 查詢在什麼時候不走(預期中的)索引(必考)
  • sql如何優化
  • explain是如何解析sql的
  • order by原理

image

JVM

  • 執行時資料區域(記憶體模型)(必考)
  • 垃圾回收機制(必考)
  • 垃圾回收演算法(必考)
  • Minor GC和Full GC觸發條件
  • GC中Stop the world(STW)
  • 各垃圾回收器的特點及區別
  • 雙親委派模型
  • JDBC和雙親委派模型關係
  • JVM 中一次完整的 GC 流程是什麼樣子的,物件如何晉升到老年代,說說你知道的幾種主要的 JVM 引數

image

Spring

  • Spring的IOC/AOP的實現(必考)
  • 動態代理的實現方式(必考)
  • Spring如何解決迴圈依賴(三級快取)(必考)
  • Spring的後置處理器
  • Spring的@Transactional如何實現的(必考)
  • Spring的事務傳播級別
  • BeanFactory和ApplicationContext的聯絡和區別

image

其他

  • 高併發系統的限流如何實現
  • 高併發秒殺系統的設計
  • 負載均衡如何設計

作業系統篇

  • 程式和執行緒的區別
  • 程式同步的幾種方式
  • 執行緒間同步的方式
  • 什麼是緩衝區溢位。有什麼危害,其原因是什麼
  • 程式中有哪幾種狀態
  • 分頁和分段有什麼區別

image

多執行緒篇

  • 多執行緒的幾種實現方式,什麼是執行緒安全
  • volatile 的原理,作用,能代替鎖嗎?
  • sleep 和 wait 的區別
  • sleep(0)的意義
  • Lock 和 Synchronized 的區別
  • synchronized 的原理是什麼,一般用在什麼地方(比如載入靜態方法和非靜態方法的區別)

image

合理的職業規劃

什麼是職業規劃—-就是你短期或者長期的一個職業計劃!大道理不講,我們簡單點。先問你幾個問題:

a.你工作幾年了,你願意一直和新入行的新手一樣就是個簡單的程式設計師嗎?
b. 你願意一直寫程式碼,而不關心其他嗎?
c. 一個專案的前期需求,設計,後期部署維護,領導找到你,你說我們搞不定,行嗎?
程式設計師不是敲程式碼的機器。第一年太多東西不懂,你可以一切聽從老大的安排,敲敲程式碼,看看資料庫,測試自己和別人的程式碼;但是第二年,你還是這樣嗎?不可能的,一年的經驗你完全可以入行了,是時候該學習怎麼進行需求分析,怎麼設計資料庫,怎麼寫各類文件,怎麼寫更好的程式碼?這是高階程式設計師的要求!

什麼是高階程式設計師?

具有分析設計能力,能進行技術攻關,而且具有某行業深厚背景的程式設計師!

所有,一個專案立項後,你要積極的參與到前期設計中,跟老同志們一道思考分析問題,學習經驗!OK,你這就成長啦!

千萬不要認為程式設計師就是寫程式碼的哦!!!

而且,通過一個專案的開發,你要能粗略的統計出一個功能的開發時間;比如一個模組有20個小功能點,你開發了80個小時,每個小功能點平均2小時——這時在前期就能評估工作量啦。當然每個人的效率和工作質量是不同的,因人而異,但是大概的工作量應該是可以統計出來的,用於統計一個專案的工作週期;

今天給大家分享在這次跳槽中整理的Java面試大綱,其中大部分都是面試過程中的面試題,可以對照這查漏補缺,當然了,這裡所列的肯定不可能覆蓋全部方式。

好的,現在進入面試題正文。

Java基礎

1、List 和 Set 的區別
2、HashSet 是如何保證不重複的
3、HashMap 是執行緒安全的嗎,為什麼不是執行緒安全的(最好畫圖說明多執行緒環境下不安全)?
4、HashMap 的擴容過程
5、HashMap 1.7 與 1.8 的 區別,說明 1.8 做了哪些優化,如何優化的?
6、final finally finalize
7、強引用 、軟引用、 弱引用、虛引用
8、Java反射
9、Arrays.sort 實現原理和 Collection 實現原理
10、LinkedHashMap的應用
11、cloneable介面實現原理
12、異常分類以及處理機制
13、wait和sleep的區別
14、陣列在記憶體中如何分配

Java 併發

1、synchronized 的實現原理以及鎖優化?
2、volatile 的實現原理?
3、Java 的訊號燈?
4、synchronized 在靜態方法和普通方法的區別?
5、怎麼實現所有執行緒在等待某個事件的發生才會去執行?
6、CAS?CAS 有什麼缺陷,如何解決?
7、synchronized 和 lock 有什麼區別?
8、Hashtable 是怎麼加鎖的 ?
9、HashMap 的併發問題?
10、ConcurrenHashMap 介紹?1.8 中為什麼要用紅黑樹?
11、AQS
12、如何檢測死鎖?怎麼預防死鎖?
13、Java 記憶體模型?
14、如何保證多執行緒下 i++ 結果正確?
15、執行緒池的種類,區別和使用場景?
16、分析執行緒池的實現原理和執行緒的排程過程?
17、執行緒池如何調優,最大數目如何確認?
18、ThreadLocal原理,用的時候需要注意什麼?
19、CountDownLatch 和 CyclicBarrier 的用法,以及相互之間的差別?
20、LockSupport工具
21、Condition介面及其實現原理
22、Fork/Join框架的理解
23、分段鎖的原理,鎖力度減小的思考
24、八種阻塞佇列以及各個阻塞佇列的特性

Spring

1、BeanFactory 和 FactoryBean?
2、Spring IOC 的理解,其初始化過程?
3、BeanFactory 和 ApplicationContext?
4、Spring Bean 的生命週期,如何被管理的?
5、Spring Bean 的載入過程是怎樣的?
6、如果要你實現Spring AOP,請問怎麼實現?
7、如果要你實現Spring IOC,你會注意哪些問題?
8、Spring 是如何管理事務的,事務管理機制?
9、Spring 的不同事務傳播行為有哪些,幹什麼用的?
10、Spring 中用到了那些設計模式?
11、Spring MVC 的工作原理?
12、Spring 迴圈注入的原理?
13、Spring AOP的理解,各個術語,他們是怎麼相互工作的?
14、Spring 如何保證 Controller 併發的安全?

Netty

1、BIO、NIO和AIO
2、Netty 的各大元件
3、Netty的執行緒模型
4、TCP 粘包/拆包的原因及解決方法
5、瞭解哪幾種序列化協議?包括使用場景和如何去選擇
6、Netty的零拷貝實現
7、Netty的高效能表現在哪些方面

分散式相關

1、Dubbo的底層實現原理和機制
2、描述一個服務從釋出到被消費的詳細過程
3、分散式系統怎麼做服務治理
4、介面的冪等性的概念
5、訊息中介軟體如何解決訊息丟失問題
6、Dubbo的服務請求失敗怎麼處理
7、重連機制會不會造成錯誤
8、對分散式事務的理解
9、如何實現負載均衡,有哪些演算法可以實現?
10、Zookeeper的用途,選舉的原理是什麼?
11、資料的垂直拆分水平拆分。
12、zookeeper原理和適用場景
13、zookeeper watch機制
14、redis/zk節點當機如何處理
15、分散式叢集下如何做到唯一序列號
16、如何做一個分散式鎖
17、用過哪些MQ,怎麼用的,和其他mq比較有什麼優缺點,MQ的連線是執行緒安全的嗎
18、MQ系統的資料如何保證不丟失
19、列舉出你能想到的資料庫分庫分表策略;分庫分表後,如何解決全表查詢的問題
20、zookeeper的選舉策略
21、全域性ID

資料庫

1、mysql分頁有什麼優化
2、悲觀鎖、樂觀鎖
3、組合索引,最左原則
4、mysql 的表鎖、行鎖
5、mysql 效能優化
6、mysql的索引分類:B+,hash;什麼情況用什麼索引
7、事務的特性和隔離級別

快取

1、Redis用過哪些資料資料,以及Redis底層怎麼實現
2、Redis快取穿透,快取雪崩
3、如何使用Redis來實現分散式鎖
4、Redis的併發競爭問題如何解決
5、Redis持久化的幾種方式,優缺點是什麼,怎麼實現的
6、Redis的快取失效策略
7、Redis叢集,高可用,原理
8、Redis快取分片
9、Redis的資料淘汰策略

JVM

1、詳細jvm記憶體模型
2、講講什麼情況下回出現記憶體溢位,記憶體洩漏?
3、說說Java執行緒棧
4、JVM 年輕代到年老代的晉升過程的判斷條件是什麼呢?
5、JVM 出現 fullGC 很頻繁,怎麼去線上排查問題?
6、類載入為什麼要使用雙親委派模式,有沒有什麼場景是打破了這個模式?
7、類的例項化順序
8、JVM垃圾回收機制,何時觸發MinorGC等操作
9、JVM 中一次完整的 GC 流程(從 ygc 到 fgc)是怎樣的
10、各種回收器,各自優缺點,重點CMS、G1
11、各種回收演算法
12、OOM錯誤,stackoverflow錯誤,permgen space錯誤

最新2020整理收集的一些面試題(都整理成文件),有很多幹貨,包含mysql,netty,spring,執行緒,spring cloud等詳細講解,也有詳細的學習規劃圖,面試題整理等在這裡插入圖片描述
如果你需要這份完整版的面試筆記,只需你多多支援我這篇文章。

多多支援,即可免費獲取資料——三連之後(承諾:100%免費)

快速入手通道:(點這裡)下載!誠意滿滿!!

整理不易,覺得有幫助的朋友可以幫忙點贊分享支援一下小編~

你的支援,我的動力;祝各位前程似錦,offer不斷!!!

相關文章