Java Memory management

Sathishkumar
4 min readMar 20, 2021

--

Memory management is the process of allocating and de-allocation of objects. Java does memory management automatically. Java uses automatic memory management system called Garbage Collector.

This enables faster development with less boilerplate code, while eliminating memory leaks and other memory-related problems.

Ironically, Java garbage collection seems to work too well, creating and removing too many objects. Most memory-management issues are solved, but often at the cost of creating serious performance problems. Making garbage collection adaptable to all kinds of situations has led to a complex and hard-to-optimize system. To wrap your head around garbage collection, you need first to understand how memory management works in a Java Virtual Machine (JVM).

Java Virtual Machine Architecture

JVM is only a specification and it has many different implementations. You can mapping with an interface and many implements in your code.

How Garbage Collection works

Many people think garbage collection collects and discards dead objects. In reality, Java garbage collection is doing the opposite! Live objects are tracked and everything else designated garbage. As you’ll see, this fundamental misunderstanding can lead to many performance problems.

First will start with heap memory, Heap memory is used for dynamic allocation. In most configurations the operating system allocates the heap in advance to be managed by the JVM while the program is running.

Memory Layout

All objects are allocated on the heap area managed by the JVM. Every item that the developer uses is treated this way, including class objects, static variables, and even the code itself. As long as an object is being referenced, the JVM considers it alive. Once an object is no longer referenced and therefore is not reachable by the application code, the garbage collector removes it and reclaims the unused memory

Garbage Collection Roots

There are four kinds of GC roots in Java:

  • Local variables are kept alive by the stack of a thread. This is not a real object virtual reference and thus is not visible. For all intents and purposes, local variables are GC roots.
  • Active Java threads are always considered live objects and are therefore GC roots. This is especially important for thread local variables.
  • Static variables are referenced by their classes. This fact makes them de facto GC roots. Classes themselves can be garbage-collected, which would remove all referenced static variables.
  • JNI References are Java objects that the native code has created as part of a JNI call. Objects thus created are treated specially because the JVM does not know if it is being referenced by the native code or not. Such objects represent a very special form of GC root.

Marking and Sweeping

JVM internally uses mark and sweep algorithm to internally collect all the un-used objects. Mark and sweep is straightforward, its a two step process.

  1. The algorithm traverses all object references, starting with the GC roots, and marks every object found as alive.
  2. All of the heap memory that is not occupied by marked objects is reclaimed. It is simply marked as free, essentially swept free of unused objects.

Garbage collection is intended to remove the cause for classic memory leaks: unreachable-but-not-deleted objects in memory. However, this works only for memory leaks in the original sense. It’s possible to have unused objects that are still reachable by an application because the developer simply forgot to dereference them. Such objects cannot be garbage-collected. Even worse, such a logical memory leak cannot be detected by any software. Even the best analysis software can only highlight suspicious objects. We will examine memory leak analysis in the Analysing the Performance Impact of Memory Utilisation and Garbage Collection section, below.

When objects are no longer referenced directly or indirectly by a GC root, they will be removed. There are no classic memory leaks. Analysis cannot really identify memory leaks; it can only point out suspicious objects.

Conclusion

Knowing how memory is organised gives you the advantage of writing good and optimised code in terms of memory resources. In advantage, you can tune up your running JVM, by providing different configurations that are the most suitable for your running application. Spotting and fixing memory leaks is just an easy thing to do.

--

--

Sathishkumar
Sathishkumar

Written by Sathishkumar

Technical Lead, We will do design and develop a project from scratch. We do Python, Java, PHP development.

No responses yet