一、基礎篇
1.1 JVM 該內容可以查看書籍《深入理解java虛擬機》
1.1.1. Java內存模型,Java內存管理,Java堆和棧,垃圾回收
1.1.2. 瞭解JVM各種參數及調優
1.1.3. 學習使用Java工具
jps, jstack, jmap, jconsole, jinfo, jhat, javap, …
1.1.4. 學習Java診斷工具
1.1.5. 自己編寫各種outofmemory,stackoverflow程序
HeapOutOfMemory
Young OutOfMemory
MethodArea OutOfMemory
ConstantPool OutOfMemory
DirectMemory OutOfMemory
Stack OutOfMemory Stack OverFlow
1.1.6. 使用工具嘗試解決以下問題,並寫下總結
當一個Java程序響應很慢時如何查找問題 當一個Java程序頻繁FullGC時如何解決問題,如何查看垃圾回收日誌 當一個Java應用發生OutOfMemory時該如何解決,年輕代、年老代、永久代解決辦法不同,導致原因也不同
1.2. Java基礎知識
1.2.1. 閱讀源代碼(已經查看完的文字顏色改爲紅色)
java.lang.String java.lang.Integer
Java.lang.Long
java.lang.Enum java.math.BigDecimal java.lang.ThreadLocal java.lang.ClassLoader & java.net.URLClassLoader java.util.ArrayList & java.util.LinkedList
java.util.HashMap & java.util.LinkedHashMap & java.util.TreeMap (需要深入研究紅黑樹)
java.util.HashSet & java.util.LinkedHashSet & java.util.TreeSet
1.2.2. 熟悉Java中各種變量類型
1.2.3. 熟悉Java String的使用,熟悉String的各種函數
1.2.4. 熟悉Java中各種關鍵字
1.2.5. 學會使用List,Map,Stack,Queue,Set
上述數據結構的遍歷 上述數據結構的使用場景 Java實現對Array/List排序java.uti.Arrays.sort() java.util.Collections.sort() Java實現對List去重 Java實現對List去重,並且需要保留數據原始的出現順序 Java實現最近最少使用cache,用LinkedHashMap
1.2.6. Java IO&Java NIO,並學會使用
java.io.* java.nio.* nio和reactor設計模式 文件編碼,字符集
1.2.7. Java反射與javassist
反射與工廠模式 java.lang.reflect.*
1.2.8. Java序列化
java.io. Serializable 什麼是序列化,爲什麼序列化 序列化與單例模式 google序列化protobuf
1.2.9. 虛引用,弱引用,軟引用
java.lang.ref.* 實驗這些引用的回收
1.2.10. 熟悉Java系統屬性
java.util.Properties
1.2.11. 熟悉Annotation用法
java.lang.annotation.*
1.2.12. JMS
javax.jms.*
1.2.13. JMX
java.lang.management.* javax.management.*
1.2.14. 泛型和繼承,泛型和擦除
1.2.15. 自動拆箱裝箱與字節碼
1.2.16. 實現Callback
1.2.17. java.lang.Void類使用
1.2.18. Java Agent,premain函數
java.lang.instrument
1.2.19. 單元測試
Junit,Jmockit,djUnit
1.2.20. Java實現通過正則表達式提取一段文本中的電子郵件,並將@替換爲#輸出
java.util.regex.*
1.2.21. 學習使用常用的Java工具庫
commons.lang, commons.*… guava-libraries Netty
1.2.22. 什麼是API&SPI
1.3. Java併發編程
1.3.1. 閱讀源代碼,並學會使用
java.lang.Thread
java.lang.Runnable
java.util.concurrent.Callable
java.util.concurrent.locks.ReentrantLock
java.util.concurrent.locks.ReentrantReadWriteLock
java.util.concurrent.atomic.Atomic*
java.util.concurrent.Semaphore
java.util.concurrent.CountDownLatch
java.util.concurrent.CyclicBarrier
java.util.concurrent.ConcurrentHashMap
java.util.concurrent.Executors
1.3.2. 學習使用線程池,自己設計線程池需要注意什麼
1.3.3. 鎖
什麼是鎖,鎖的種類有哪些,每種鎖有什麼特點,適用場景是什麼 在併發編程中鎖的意義是什麼
1.3.4. synchronized的作用是什麼,synchronized和lock
1.3.5. sleep和wait
1.3.6. wait和notify
1.3.7. 寫一個死鎖的程序
1.3.8. 什麼是守護線程,守護線程和非守護線程的區別以及用法
1.3.9. volatile關鍵字的理解
C++ volatile關鍵字和Java volatile關鍵字 happens-before語義 編譯器指令重排和CPU指令重排
1.3.10. 以下代碼是不是線程安全?爲什麼?如果爲count加上volatile修飾是否能夠做到線程安全?你覺得該怎麼做是線程安全的?
public class Sample { private static int count = 0; public static void increment() { count++; } }
1.3.11. 解釋一下下面兩段代碼的差別
// 代碼1 public class Sample { private static int count = 0; synchronized public static void increment() { count++; } } // 代碼2 public class Sample { private static AtomicInteger count = new AtomicInteger(0); public static void increment() { count.getAndIncrement(); } }