Java Garbage Collection Basics
Memory management in Java
For many programmers, Java's memory management is one of its most attractive features, because a Java programmer never has to deal directly with memory allocation and recovery. Java allows programmers to create new objects without worrying explicitly about memory allocation and deallocation, because the garbage collector automatically reclaims memory for reuse. All Java objects automatically grab the memory that they need when they are created, and when the object is no longer need, the Java Garbage Collection process reclaim the memory. That means, the Garbage Collector tracked live objects and everything else designated garbage. Through Garbage collection, most of the memory-management issues are solved, but often at the cost of creating serious performance problems.
How can an object be unreferenced?
When a typical Java program is running, it is creating new objects, such as Strings and Files, but after a certain period, those objects are not used anymore in the application. For example, take a look at the following code:
In the above code, the String str is being created on each iteration of the for loop. That means in every iteration, a little bit of memory is being allocated to make a String object. We can see that once a single iteration is executed, in the next iteration, the String object that was created in the previous iteration is not being used anymore, that object is now considered as "unreferenced object" or "garbage" .
What is Garbage Collection in Java?
In java, garbage means unreferenced objects. Garbage collection is often portrayed as the opposite of manual memory management, which requires the developer to specify which objects to deallocate and return to the memory system. For example, in other languages such as "C" , one needs to perform memory management on their own using functions such as "malloc" and "free" . In Java, JVM automatically calls garbage collector.
The garbage collector is a program which runs on the JVM which gets rid of unused objects which are not being used by a Java application anymore. It is a form of automatic memory management . In Java, an in use object, or a referenced object, means that some part of the application still maintains a pointer to that object. An unused object, or unreferenced object, is no longer referenced by any part of the application. So the memory used by an unreferenced object can be reclaimed . The garbage collector will look for objects which aren't being used anymore, and removed them, freeing up the memory so other new objects can use that piece of memory. The finalize() method is invoked each time before the object is garbage collected. This method can be used to perform clean-up processing.
How to force garbage collection in Java?
The best option is to call System.gc() which simply is a hint to the garbage collector that you want it to do a collection. But this does not mean that it'll be executed immediately. Virtual Machine internally uses some algorithm to decide when to make this call. When you make call using System.gc(), it is just a request to JVM and JVM can anytime decide to ignore it.
Is it good practice to call Garbage Collector manually?
No, it is definitely not good practice to call Garbage Collector manually. The garbage collector in Virtual Machine contains a lot of sophisticated logic to determine when and what to cleanup. Tuning it requires knowledge about details on how it works. Just putting a System.gc() somewhere in the code is not likely to help a lot, and in fact, it can even make it worse. Some people sets the relevant object to null or use System.gc() method to remove the memory explicitly. Setting it to null is not a big deal, but calling System.gc() method will affect the system performance drastically, and must not be carried out.
Advantage/Disadvantages of Garbage Collection
- Automatic deallocation allows a programmer not to worry about memory management, increasing write ability of a system, and decreasing development time and costs.
- It is automatically done by the garbage collector(a part of JVM) so we don't need to make extra efforts.
- Garbage collection is a language requirement for functional languages, which cannot use a stack-based environment because of unpredictable execution patterns.
- Explicit management introduces possibilities for making errors in memory management - for example, memory leaks. Thus, explicit deallocation decreases reliability.
When Is The Object Eligible For Garbage Collection?
Generally, an object becomes eligible for garbage collection in Java on following cases:
- Any instances that cannot be reached by a live thread.
- Circularly referenced instances that cannot be reached by any other instances.
- If an object has only lived weak references via WeakHashMap it will be eligible for garbage collection.
- The object is created inside a block and reference goes out scope once control exit that block.
More on... Eligible For Garbage Collection
Does GC guarantee that a program will not run out of memory?
No, Garbage collection (GC) does not guarantee that a program will not run out of memory. It is the developer's responsibility to ensure that objects no longer in use are no longer referenced by the application. That way the garbage collector can do its job and reclaim memory used by these objects.
More on.... Does garbage collection guarantee
Does assigning objects to null in Java impact garbage collection?
Not necessarily. An object becomes eligible for garbage collection when there are no live threads anymore that hold a reference to the object. Explicitly setting a reference to null instead of just letting the variable go out of scope, does not help the garbage collector , unless the object held is very large.
More on.... null in Java impact garbage collection
- Java Interview Questions-Core Faq - 1
- Java Interview Questions-Core Faq - 2
- Java Interview Questions-Core Faq - 3
- Important features of Java
- What is the difference between JDK and JRE?
- What gives Java its 'write once and run anywhere' nature?
- What is JVM and is it platform independent?
- What is Just-In-Time (JIT) compiler?
- What is NullPointerException in Java
- Difference between Stack and Heap memory in Java
- How to set the maximum memory usage for JVM?
- What is numeric promotion?
- Why do we need Generic Types in Java?
- What does it mean to be static in Java?
- What are final variables in Java?
- How Do Annotations Work in Java?
- How do I use the ternary operator in Java?
- What is instanceof keyword in Java?
- How ClassLoader Works in Java?
- What are fail-safe and fail-fast Iterators in Java
- What are method references?
- "Cannot Find Symbol" compile error
- Difference between system.gc() and runtime.gc()
- How to convert TimeStamp to Date in Java?
- Does garbage collection guarantee that a program will not run out of memory?
- How setting an Object to null help Garbage Collection?
- How do objects become eligible for garbage collection?
- How to calculate date difference in Java
- Difference between Path and Classpath
- Is Java "pass-by-reference" or "pass-by-value"?
- Difference between static and nonstatic methods java
- Why Java does not support pointers?
- What is package in Java?
- What are wrapper classes?
- What is singleton class in Java?
- Difference between Java Local Variable, Instance Variable and a Class Variable?
- Can a top level class be private or protected in java
- Are Polymorphism , Overloading and Overriding similar concepts?
- How to Use Locks in Java
- Why Multiple Inheritance is Not Supported in Java
- Why Java is not a pure Object Oriented language?
- Why can't a Java class be declared as static?
- Difference between Abstract class and Interface in Java
- Why do I need to override the equals and hashCode methods in Java?
- Why does Java not support operator overloading?
- What’s meant by anonymous class in Java?
- Static Vs Dynamic class loading in Java
- Why am I getting a NoClassDefFoundError in Java?
- How to generate random integers within a specific range in Java
- What's the meaning of System.out.println in Java?
- What is the purpose of Runtime and System class?
- What is finally block in Java?
- What is difference between final, finally and finalize?
- What is try-with-resources in java?
- What is a stacktrace?
- What is the meaning of immutable in terms of String?
- What are different ways to create a string object in Java?
- Difference between String and StringBuffer/StringBuilder in Java
- What is the difference between creating String as new() and literal?
- How do I convert String to Date object in Java?
- How do I create a Java string from the contents of a file?
- What actually causes a StackOverflow error in Java?
- Why is char preferred over String for storage of password in Java
- What is I/O Filter and how do I use it in Java?
- Serialization and Deserialization in Java
- Understanding transient variables in Java
- What is Externalizable in Java?
- What is the purpose of serialization/deserialization in Java?
- What is the Difference between byte stream and Character streams
- How to append text to an existing file in Java
- Read/convert an InputStream to a String in Java
- What is the difference between Reader and InputStream in Java
- Introduction to Java threads
- What is synchronization Java?
- Static synchronization Vs non static synchronization in Java
- Java Thread Deadlock Tutorial
- What is Daemon thread in Java
- Difference between implements Runnable and extends Thread in Java
- What is the volatile keyword in Java
- What are the basic interfaces of Java Collections Framework
- What are the differences between ArrayList and Vector in Java
- What is the difference between ArrayList and LinkedList?
- What is the difference between List and Set in Java
- Difference between HashSet and HashMap in Java
- Difference between HashMap and Hashtable in Java?
- How does the hashCode() method of java works?
- Difference between capacity() and size() of Vector in Java