All Downloads are FREE. Search and download functionalities are using the official Maven repository.

scala.collection.concurrent.MainNode Maven / Gradle / Ivy

There is a newer version: 2.11.2
Show newest version
/*                     __                                               *\
**     ________ ___   / /  ___     Scala API                            **
**    / __/ __// _ | / /  / _ |    (c) 2003-2013, LAMP/EPFL             **
**  __\ \/ /__/ __ |/ /__/ __ |    http://scala-lang.org/               **
** /____/\___/_/ |_/____/_/ | |                                         **
**                          |/                                          **
\*                                                                      */

package scala.collection.concurrent;



import java.util.concurrent.atomic.AtomicReferenceFieldUpdater;



abstract class MainNode extends BasicNode {
    
    public static final AtomicReferenceFieldUpdater updater = AtomicReferenceFieldUpdater.newUpdater(MainNode.class, MainNode.class, "prev");
    
    public volatile MainNode prev = null;
    
    public abstract int cachedSize(Object ct);
    
    public boolean CAS_PREV(MainNode oldval, MainNode nval) {
	return updater.compareAndSet(this, oldval, nval);
    }
    
    public void WRITE_PREV(MainNode nval) {
	updater.set(this, nval);
    }
    
    // do we need this? unclear in the javadocs...
    // apparently not - volatile reads are supposed to be safe
    // irregardless of whether there are concurrent ARFU updates
    public MainNode READ_PREV() {
	return updater.get(this);
    }
    
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy