Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

what are read barriers and write barriers in synchronized block

I am looking into how a synchronized and volatile variable works in java and i came across a concept called read and write barrier . Can anyone help me to understand the meaning of this terms

like image 231
csk Avatar asked Aug 28 '13 10:08

csk


2 Answers

( the answers above are quite complete), I just want to demonstrate the concept with a simple scheme

 Thread 1                                                             Thread 2


   |          
   |                                                                      
   |                                                                      |
   |                                                                      |
   |  Everything Thread 1                                                 |
   |   wrote before here                                                  |
   |                                                                      |
   |                                                                      |
    _ _ _ _ _ _ _ _ _ _                                                   |
      ( write  barrier)         (happens before)         (read barrier)   |
   |                                                     _ _  _ _ _ _ _ _  
   |
   |                                                   is guaranteed      |
   |                                                  to be visible to    |
   |                                                  Thread 2            |
   |                                                                      |
like image 133
Salah Eddine Taouririt Avatar answered Oct 20 '22 16:10

Salah Eddine Taouririt


A memory barrier is a conceptual "line" in your code that prevents the compiler from making certain optimizations and may insert special "sync up" commands to the processor. Normally, the compiler can look within a particular method and see that certain instructions can be moved around without changing the meaning of the code. For example, if you have

int x = 0, y = 0;
x++;
y++;

If the compiler figured that there was some benefit, it could instead output code for

y++;
x++;

However, if x and y are fields in some class, so that they can be seen from other threads, the other thread might be modifying the values while your method is running.

A memory barrier forces the compiler to recheck the values of specific variables (in Java, those are ones that are volatile and the Atomic* classes) in case some other thread has modified them while the method's been running, and it keeps the compiler from making reorderings that might accidentally change the results of a calculation. On systems that support multiple cores/processors, the compiler will also force the processor to check to make sure that some other processor or hardware device hasn't modified the variable in the meantime. Java (as of Java 5) has an extremely well-defined set of rules for how this works called happens-before.

This FAQ has some useful explanations that were written at the time the Java Memory Model was being developed. Note that while the concept of a memory barrier is cross-language, most languages don't have as clearly defined rules about them as Java.

like image 24
chrylis -cautiouslyoptimistic- Avatar answered Oct 20 '22 16:10

chrylis -cautiouslyoptimistic-