Recently, many friends have eaten ant Financial’s sour lemon, and they think the blessing ma said still exists. Someone asked me, is it difficult to get into Ali?

Oh, please. Tian didn’t go in. How should I know?

However, in the spirit of getting to the bottom of the matter, small day search a lot of Ali Java development position recruitment information, the common technical requirements of those general summarized, have not had time to do statistics, but the following screenshot is probably not out of ten, we will have a look.

It seems that the picture is not too clear, there is no way, xiaotian cut several times, are like this.

Or wait for xiaotian to finish all the statistics of the content to do a more clear picture put out for everyone to see! Here xiao Tian will share a series of articles about Ali’s interview, one is to give some advice to your fans and friends, but also want to accumulate their own towards this direction

Well, without further ado, one of the most important technical points to share is the JVM.

In-depth understanding of the JVM

Let’s take a look at some of the core things that the JVM needs to know.

Xmind figure

1, the thread

2. JVM memory area

2.1. Program counter (thread private)

2.2. Virtual Stack (thread private)

2.3. Local method area (thread private)

2.4. Heap (Heap- thread shared) – Run-time data area

2.5. Method area/persistent generation (thread sharing)

3. JVM runtime memory

3.1. The new generation

  • Eden area
  • ServivorFrom
  • ServivorTo
  • MinorGC process (copy -> empty -> swap)
  • Copy Eden, servicorFrom to ServicorTo, age +1
  • Clear Eden and servicorFrom
  • ServicorTo and ServicorFrom are interchangeable

3.2. The old age

3.3. The permanent generation

  • JAVA8 and metadata

4. Garbage collection and algorithm

4.1. How to identify garbage

  • Reference counting method
  • Accessibility analysis

4.2. Mark-sweep algorithm

4.3. Copying Algorithms

4.4. Mark-compact algorithm

4.5. Generational collection algorithm

  • New generation and replication algorithms
  • Old age and tag copy algorithm

JAVA four reference types

5.1 strong reference

5.2. Soft references

5.3. A weak reference

5.4. Virtual reference

6. GC generation collection algorithm VS partition collection algorithm

6.1. Generational collection algorithm

  • In the new generation – copy algorithms
  • In the old days – tag sorting algorithm

6.2. Partition collection algorithm

7. GC garbage collector

7.1. Serial garbage collector (single thread, replication algorithm)

7.2. ParNew Garbage Collector (Serial+ Multithreading)

7. Parallel Avenge collector (Multi-threaded replication algorithm, efficient)

7.4. Serial Old collector (Single-thread token collation algorithm)

7.5. Parallel Old Collector (Multi-threaded tag collation Algorithm)

7.6. CMS collector (Multi-threaded tag Clearing Algorithm)

  • Initial tag
  • Concurrent tags
  • To mark
  • Concurrent remove

7.7. G1 collector

8, JAVA IO/NIO

8.1. Block IO model

8.2. Non-blocking IO model

8.3. Multiplexing IO model

8.4. Signal-driven IO model

8.5. Asynchronous I/O model

8.6. JAVA IO package

8.7. JAVA NIO

  • NIO buffer
  • Non-blocking of NIO

8.8. The Channel

8.9. Buffer

8.10. The Selector

JVM class loading mechanism

The specific content of the above core knowledge points, I have sorted out, need friends > help forward, pay attention to add assistant Vx: Yunduoa2019 or scan the two-dimensional code below, follow the guidance of the assistant to obtain their own

2020 题 目 : The JVM

Er, warning

  1. When can stack memory overflow occur?
  2. JVM memory structure, Eden and Survivor ratio.
  3. Why should JVM memory be divided into new generation, old generation, and persistent generation? Why are there Eden and Survivor in the new generation?
  4. What does a complete GC flow in the JVM look like? How does an object progress to the past? What are some of the major JVM parameters that you know?
  5. You know which garbage collectors, their pros and cons, focus on CMS and G1, including principles, processes, and pros and cons.
  6. The realization principle of garbage collection algorithm.
  7. When there is a memory overflow, how to debug?
  8. How much do you know about the JVM memory model, such as reordering, memory barriers, happening-before, main memory, working memory, etc.
  9. Talk about Reflection in JAVA.
  10. What JVM parameters do you use online?
  11. G1 and CMS differences, throughput first and response first garbage collector selection.
  12. How to print thread stack information.
  13. Please explain the following JVM parameters?
  14. How many ways can objects be created in Java?
  15. Do objects in Java have to allocate memory on the heap?
  16. Which areas of runtime data are shared by threads and which are exclusive?
  17. Are arrays stored on a heap or stack in Java?
  18. What is the Java object creation process like?
  19. How to obtain heap and stack dump files?
  20. Trigger conditions for Minor and Full GC.
  21. What objects can be used as GC Roots in the Java language?
  22. Class loading process.
  23. Java memory leak scenario.
  24. Memory model changes in JDK1.8 VMS.
  25. Reasons for frequent GC.
  26. The JVM is tuned for high concurrency.
  27. Difference between system.gc () and Runtime.gc().

Vx: Yunduoa2019 or scan the following TWO-DIMENSIONAL code and follow the guidance of the assistant to obtain their own

There are Mysql, Redis, Spring, multithreading, data structures and more information to unlock you!

Please forward it and add assistant VX: Yunduoa2019 after following it or scan the qr code below and follow the guidance of the assistant to obtain it by yourself