工做1-5年的Java程序猿到底須要怎樣的一個技術棧?

工做1-5年的Java程序猿到底須要怎樣的一個技術棧?

前言:java

具備1-5年開發經驗的程序員 須要學習的內容其實還有不少不少。mysql

今天跟你們交流一下但願分享出來的對你們可以有幫助,這是我這些年總結出的一些經驗,相對而言比較體系,不喜勿噴:ios

閱讀時間十分鐘左右,文末贈學習資料!程序員

1、數據結構與算法基礎web

1.說一下幾種常見的排序算法和分別的複雜度。redis

2.用Java寫一個冒泡排序算法算法

3.描述一下鏈式存儲結構。spring

4.如何遍歷一棵二叉樹?sql

5.倒排一個LinkedList。數據庫

6.用Java寫一個遞歸遍歷目錄下面的全部文件。

2、Java基礎

1.接口與抽象類的區別?

2.Java中的異常有哪幾類?分別怎麼使用?

3.經常使用的集合類有哪些?好比List如何排序?

4.ArrayList和LinkedList內部的實現大體是怎樣的?他們之間的區別和優缺點?

5.內存溢出是怎麼回事?請舉一個例子?

6.==和equals的區別?

7.hashCode方法的做用?

8.NIO是什麼?適用於何種場景?

9.HashMap實現原理,如何保證HashMap的線程安全?

10.JVM內存結構,爲何須要GC?

11.NIO模型,select/epoll的區別,多路複用的原理

12.Java中一個字符佔多少個字節,擴展再問int, long, double佔多少字節

13.建立一個類的實例都有哪些辦法?

14.final/finally/finalize的區別?

15.Session/Cookie的區別?

16.String/StringBuffer/StringBuilder的區別,擴展再問他們的實現?

17.Servlet的生命週期?

18.如何用Java分配一段連續的1G的內存空間?須要注意些什麼?

19.Java有本身的內存回收機制,但爲何還存在內存泄露的問題呢?

20.什麼是java序列化,如何實現java序列化?(寫一個實例)?

21.String s = new String("abc");建立了幾個 String Object?

3、JVM

1.JVM堆的基本結構。

2.JVM的垃圾算法有哪幾種?CMS垃圾回收的基本流程?

3.JVM有哪些經常使用啓動參數能夠調整,描述幾個?

4.如何查看JVM的內存使用狀況?

5.Java程序是否會內存溢出,內存泄露狀況發生?舉幾個例子。

6.你經常使用的JVM配置和調優參數都有哪些?分別什麼做用?

7.JVM的內存結構?

8.經常使用的GC策略,何時會觸發YGC,何時觸發FGC?

4、多線程/併發

1.如何建立線程?如何保證線程安全?

2.如何實現一個線程安全的數據結構

3.如何避免死鎖

4.Volatile關鍵字的做用?

5.HashMap在多線程環境下使用須要注意什麼?爲何?

6.Java程序中啓動一個線程是用run()仍是start()?

7.什麼是守護線程?有什麼用?

8.什麼是死鎖?如何避免

9.線程和進程的差異是什麼?

10.Java裏面的Threadlocal是怎樣實現的?

11.ConcurrentHashMap的實現原理是?

12.sleep和wait區別

13.notify和notifyAll區別

14.volatile關鍵字的做

15.ThreadLocal的做用與實現

16.兩個線程如何串行執行

17.上下文切換是什麼含義

18.能夠運行時kill掉一個線程嗎?

19.什麼是條件鎖、讀寫鎖、自旋鎖、可重入鎖?

20.線程池ThreadPoolExecutor的實現原理?

5、Linux使用與問題分析排查

1.使用兩種命令建立一個文件?

2.硬連接和軟連接的區別?

3.Linux經常使用命令有哪些?

4.怎麼看一個Java線程的資源耗用?

5.Load太高的可能性有哪些?

6./etc/hosts文件什麼作用?

7.如何快速的將一個文本中全部「abc」替換爲「xyz」?

8.如何在log文件中搜索找出error的日誌?

9.發現磁盤空間不夠,如何快速找出佔用空間最大的文件?

10.Java服務端問題排查(OOM,CPU高,Load高,類衝突)

11.Java經常使用問題排查工具及用法(top, iostat, vmstat, sar, tcpdump, jvisualvm, jmap, jconsole)

12.Thread dump文件如何分析(Runnable,鎖,代碼棧,操做系統線程ID關聯)

13.如何查看Java應用的線程信息?

6、框架使用

1.描述一下Hibernate的三個狀態?

2.Spring中Bean的生命週期。

3.SpringMVC或Struts處理請求的流程。

4.Spring AOP解決了什麼問題?怎麼實現的?

5.Spring事務的傳播屬性是怎麼回事?它會影響什麼?

6.Spring中BeanFactory和FactoryBean有什麼區別?

7.Spring框架中IOC的原理是什麼?

8.spring的依賴注入有哪幾種方式

9.struts工做流程

10.用Spring如何實現一個切面?

11.Spring 如何實現數據庫事務?

12.Hibernate對一二級緩存的使用,Lazy-Load的理解;

13.mybatis如何實現批量提交?

7、數據庫相關

1.MySQL InnoDB、Mysaim的特色?

2.樂觀鎖和悲觀鎖的區別?

3.數據庫隔離級別是什麼?有什麼做用?

4.MySQL主備同步的基本原理。

5.select * from table t where size > 10 group by size order by size的sql語句執行順序?

6.如何優化數據庫性能(索引、分庫分表、批量操做、分頁算法、升級硬盤SSD、業務優化、主從部署)

7.SQL什麼狀況下不會使用索引(不包含,不等於,函數)

8.通常在什麼字段上建索引(過濾數據最多的字段)

9.如何從一張表中查出name字段不包含「XYZ」的全部行?

10.MySQL,B+索引實現,行鎖實現,SQL優化

11.Redis,RDB和AOF,如何作高可用、集羣

12.如何解決高併發減庫存問題

13.mysql存儲引擎中索引的實現機制;

14.數據庫事務的幾種粒度;

15.行鎖,表鎖;樂觀鎖,悲觀鎖

8、網絡協議和網絡編程

1.TCP創建鏈接的過程。

2.TCP斷開鏈接的過程。

3.瀏覽器發生302跳轉背後的邏輯?

4.HTTP協議的交互流程。HTTP和HTTPS的差別,SSL的交互流程?

5.Rest和Http什麼關係? 你們都說Rest很輕量,你對Rest風格如何理解?

6.TCP的滑動窗口協議有什麼用?講講原理。

7.HTTP協議都有哪些方法?

8.交換機和路由器的區別?

9.Socket交互的基本流程?

10.http協議(報文結構,斷點續傳,多線程下載,什麼是長鏈接)

11.tcp協議(建連過程,慢啓動,滑動窗口,七層模型)

12.webservice協議(wsdl/soap格式,與rest協議的區別)

13.NIO的好處,Netty線程模型,什麼是零拷貝

9、Redis等緩存系統/中間件/NoSQL/一致性Hash等

1.列舉一個經常使用的Redis客戶端的併發模型。

2.HBase如何實現模糊查詢?

3.列舉一個經常使用的消息中間件,若是消息要保序如何實現?

4.如何實現一個Hashtable?你的設計如何考慮Hash衝突?如何優化?

5.分佈式緩存,一致性hash

6.LRU算法,slab分配,如何減小內存碎片

7.如何解決緩存單機熱點問題

8.什麼是布隆過濾器,其實現原理是? False positive指的是?

9.memcache與redis的區別

10.zookeeper有什麼功能,選舉算法如何進行

11.map/reduce過程,如何用map/reduce實現兩個數據源的聯合統計

10、設計模式與重構

1.你能舉例幾個常見的設計模式

2.你在設計一個工廠的包的時候會遵循哪些原則?

3.你能列舉一個使用了Visitor/Decorator模式的開源項目/庫嗎?

4.你在編碼時最經常使用的設計模式有哪些?在什麼場景下用?

5.如何實現一個單例?

6.代理模式(動態代理)

7.單例模式(懶漢模式,併發初始化如何解決,volatile與lock的使用)

8.JDK源碼裏面都有些什麼讓你印象深入的設計模式使用,舉例看看?

順便給你們推薦一個Java架構方面的交流學習羣:725633148,裏面會分享一些資深架構師錄製的視頻錄像:有Spring,MyBatis,Netty源碼分析,高併發、高性能、分佈式、微服務架構的原理,JVM性能優化這些成爲架構師必備的知識體系。相信對於已經工做和遇到技術瓶頸的同窗,在這個羣裏會有你須要的內容。有須要的同窗請抓緊時間加入進來。

相關文章
相關標籤/搜索