Understanding the Java Virtual Machine: Memory Management
This course covers all aspects of garbage collection in Java, including how memory is split into generations and managed and how the different collectors do their job. We also cover the classes you can use to interact with the garbage collection, such as Soft, Weak, and PhantomReference.
What you'll learn
Garbage Collection (GC) is a fundamental part of Java. Understanding how GC works is core to understanding how the Java Virtual Machine (JVM) works and will help you write better applications and to improve the performance of those applications. This course will look at all aspects of garbage collection, including looking at what 'young' and 'old' generations are, how the JVM moves objects between eden and survivor spaces, how memory is promoted into the 'old' generation, how different garbage collectors work, and how they affect the running of your application. We will also look at 'card tables' and how they help manage memory in the old generation. We will examine each of the garbage collectors including the serial and parallel collectors; the CMS collector and the G1 collector. We cover the tools you can use to monitor GC including jstat and VisualVM. Finally we look at ways you interact with the GC through classes Such as Soft, Weak, and PhantomReference and their associated helpers ReferenceQueue and WeakHashMap.
Table of contents
- Introducing the Players 2m
- The Basics of Garbage Collection in the Java Virtual Machine 3m
- Minor Garbage Collects and Major Garbage Collects 5m
- How Allocations Work in the Java Virtual Machine 2m
- What Is a Cardtable and How Is It Used in Garbage Collection 5m
- Serial Versus Parallel Garbage Collectors 6m
- The G1 Garbage Collector 2m
- Which Garbage Collector to Choose 1m