Total members 11894 |It is currently Thu Nov 21, 2024 12:22 pm Login / Join Codemiles

Java

C/C++

PHP

C#

HTML

CSS

ASP

Javascript

JQuery

AJAX

XSD

Python

Matlab

R Scripts

Weka





Can anybody tell me the exact meaning of volatile keyword in Java. Also what
is the use of it. A sample program using this keyword would help me a lot.

Can anybody explain the realtime example of this keyword.




Author:
Proficient
User avatar Posts: 280
Have thanks: 1 time

Volatile
The volatile keyword is used on variables that may be modified
simultaneously by other threads. This warns the compiler to fetch them fresh
each time, rather than caching them in registers. This also inhibits certain
optimisations that assume no other thread will change the values unexpectedly.
Since other threads cannot see local variables, there is never any need to mark
local variables volatile.

The volatile modifier is used when you are working with multiple threads.
The Java language allows threads that access shared variables to keep private
working copies of the variables; this allows a more efficient implementation of
multiple threads. These working copies need be reconciled with the master
copies in the shared main memory only at prescribed synchronization points,
namely when objects are locked or unlocked. As a rule, to ensure that shared
variables are consistently and reliably updated, a thread should ensure that it
has exclusive use of such variables by obtaining a lock that, conventionally,
enforces mutual exclusion for those shared variables.

Java programming language allows threads to access shared variables. As a
rule, to ensure that shared variables are consistently and reliably updated, a
thread should ensure that it has exclusive use of such variables by obtaining a
lock that, conventionally, enforces mutual exclusion for those shared
variables.
The Java programming language provides a second mechanism, volatile fields,
that is more convenient than locking for some purposes. A field may be declared
volatile, in which case the Java memory model
ensures that all threads see a consistent value for the variable.

If, in the following example, one thread repeatedly calls the method one
(but no more than Integer.MAX_VALUE times in all), and another thread
repeatedly calls the method two:

Code:
class Test {
static int i = 0, j = 0;
static void one() { i++; j++; }
static void two() {
System.out.println("i=" + i + " j=" + j);
}
}

then method two could occasionally print a value for j that is greater
than the value of i, because the example includes no synchronization
and, under the rules explained in §17, the shared values of i and j
might be updated out of order.

One way to prevent this out-or-order behavior would be to declare
methods one and two to be synchronized

Code:
class Test {
static int i = 0, j = 0;
static synchronized void one() { i++; j++; }
static synchronized void two() {
System.out.println("i=" + i + " j=" + j);
}
}


This prevents method one and method two from being executed concurrently, and
furthermore guarantees that the shared values of i and j are both updated
before method one returns. Therefore method two never observes a value for j
greater than that for i; indeed, it always observes the same value for i and j.
Another approach would be to declare i and j to be volatile:

Code:
class Test {
static volatile int i = 0, j = 0;
static void one() { i++; j++; }
static void two() {
System.out.println("i=" + i + " j=" + j);
}
}

This allows method one and method two to be executed concurrently, but
guarantees that accesses to the shared values for i and j occur exactly as many
times, and in exactly the same order, as they appear to occur during execution
of the program text by each thread. Therefore, the shared value for j is never
greater than that for i, because each update to i must be reflected in the
shared value for i before the update to j occurs. It is possible, however, that
any given invocation of method two
might observe a value for j that is much greater than the value observed for
i, because method one might be executed many times between the moment when
method two fetches the value of i and the moment when method two fetches the
value of j.

_________________
Please recommend my post if you found it helpful


Author:
Proficient
User avatar Posts: 228
Have thanks: 0 time

thanks for this topics

_________________
M. S. Rakha, Ph.D.
Queen's University
Canada


Author:
Mastermind
User avatar Posts: 2715
Have thanks: 74 time

updated.

_________________
M. S. Rakha, Ph.D.
Queen's University
Canada


Author:
Mastermind
User avatar Posts: 2715
Have thanks: 74 time
Post new topic Reply to topic  [ 4 posts ] 

  Related Posts  to : Java volatile keyword
 java instanceof keyword     -  
 What is the use of serializable keyword in C#     -  
 Is null a keyword     -  
 switch keyword in c++ usage     -  
 2d game in java-Monster-Java 2D Game Graphics and Animation     -  
 Java course     -  
 need help in java     -  
 What is Java API?!!!     -  
 java or .net     -  
 Using FTP in java     -  



Topic Tags

Java Basics






Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
All copyrights reserved to codemiles.com 2007-2011
mileX v1.0 designed by codemiles team
Codemiles.com is a participant in the Amazon Services LLC Associates Program, an affiliate advertising program designed to provide a means for sites to earn advertising fees by advertising and linking to Amazon.com