The volatile keyword in Java
In Java, the volatile keyword is used to declare a variable as "volatile." When applied to a variable, the volatile keyword guarantees that any thread accessing the variable will always see the most up-to-date value of that variable, ensuring visibility across threads.
Volatile keyword
When a variable is declared as volatile, it serves as a hint to the Java Virtual Machine (JVM) that the variable may be accessed by multiple threads simultaneously and should not be cached in CPU registers or thread-local caches. Instead, the value of the variable is always read from and written to the main memory.
In this code, the counter variable is declared as volatile. This means that when one thread increments the counter, the change will be reflected in the counter variable in all other threads immediately.
To see how this works, let's run the following code:
This code will create two threads, one that increments the counter and one that prints the counter. If the counter variable was not declared as volatile, it is possible that the printCounter() method would sometimes print a value of the counter that is less than 1000, even though the incrementCounter() method has been called 1000 times. This is because the counter variable could be cached in the CPU registers of each thread, and the change to the counter variable made by the incrementCounter() method would not be reflected in the cached copy of the variable.
However, because the counter variable is declared as volatile, the printCounter() method will always print the most up-to-date value of the counter variable. This is because the printCounter() method will always read the value of the counter variable directly from main memory, bypassing the CPU registers.
Use of volatile keyword
The use of the volatile keyword provides two main guarantees: visibility and atomicity.
- Visibility: When a variable is declared as volatile, any changes made to its value by one thread are immediately visible to all other threads. This ensures that all threads accessing the variable will see the most recent value, even if it was modified by a different thread.
- Atomicity: While volatile ensures visibility, it does not guarantee atomicity by itself. Atomicity refers to the property of an operation being performed as a single, indivisible unit. Volatile variables are not atomic for compound operations, such as incrementing a counter. For operations that require atomicity, the atomic classes provided in the java.util.concurrent.atomic package should be used instead.
The usage of the volatile keyword should be limited to cases where variables are shared between threads, and simple read and write operations need to be synchronized in terms of visibility. It is particularly useful in scenarios where a variable is updated by one thread and read by another without any additional synchronization mechanisms.
Conclusion
The volatile keyword is a powerful tool that can be used to ensure that multiple threads see the most up-to-date value of a variable. However, it is important to use it correctly and to understand its limitations.
- Java Interview Questions-Core Faq - 1
- Java Interview Questions-Core Faq - 2
- Java Interview Questions-Core Faq - 3
- Features of Java Programming Language (2024)
- Difference between Java and JavaScript?
- 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 the garbage collector in Java?
- 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?
- Generics in Java
- Static keyword 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 in Java?
- "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 in Java
- Is Java "pass-by-reference" or "pass-by-value"?
- Difference between static and nonstatic methods java
- Why Java does not support pointers?
- What is a package in Java?
- What are wrapper classes in Java?
- 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?
- Locking Mechanism in Java
- Why Multiple Inheritance is Not Supported in Java
- Why Java is not a pure Object Oriented language?
- Static class in Java
- 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?
- Anonymous Classes in Java
- Static Vs Dynamic class loading in Java
- Why am I getting a NoClassDefFoundError in Java?
- How to Generate Random Number in Java
- What's the meaning of System.out.println in Java?
- What is the purpose of Runtime and System class in Java?
- The finally Block in Java
- Difference between final, finally and finalize
- What is try-with-resources in java?
- What is a stacktrace?
- Why String is immutable in Java ?
- What are different ways to create a string object in Java?
- Difference between String and StringBuffer/StringBuilder in Java
- Difference between creating String as new() and literal | Java
- 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
- How to convert InputStream object to a String in Java
- What is the difference between Reader and InputStream in Java
- Introduction to Java threads
- Synchronization in Java
- Static synchronization Vs non static synchronization in Java
- Deadlock in Java with Examples
- What is Daemon thread in Java
- Implement Runnable vs Extend Thread in Java
- What are the basic interfaces of Java Collections Framework
- Difference between ArrayList and Vector | 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
- What is a Java ClassNotFoundException?
- How to fix java.lang.UnsupportedClassVersionError