java工程師成神之路-基礎篇

一、基礎篇

1.1 JVM  該內容可以查看書籍《深入理解java虛擬機》

 1.1.1. Java內存模型,Java內存管理,Java堆和棧,垃圾回收

 1.1.2. 瞭解JVM各種參數及調優

 1.1.3. 學習使用Java工具

jpsjstackjmap, jconsole, jinfo, jhat, javap, …

 1.1.4. 學習Java診斷工具

1.1.5. 自己編寫各種outofmemorystackoverflow程序

  • 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. 學會使用ListMapStackQueueSet

上述數據結構的遍歷 上述數據結構的使用場景 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 Agentpremain函數

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的作用是什麼,synchronizedlock

1.3.5. sleepwait

1.3.6. waitnotify

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();
 
  }
 
}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章