| 
JavaTM 2 Platform Standard Ed. 5.0  | 
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectjava.util.concurrent.atomic.AtomicStampedReference<V>
V - The type of object referred to by this referencepublic class AtomicStampedReference<V>
An AtomicStampedReference maintains an object reference along with an integer "stamp", that can be updated atomically.
Implementation note. This implementation maintains stamped references by creating internal objects representing "boxed" [reference, integer] pairs.
| Constructor Summary | |
|---|---|
AtomicStampedReference(V initialRef,
                       int initialStamp)
Creates a new AtomicStampedReference with the given initial values.  | 
|
| Method Summary | |
|---|---|
 boolean | 
attemptStamp(V expectedReference,
             int newStamp)
Atomically sets the value of the stamp to the given update value if the current reference is == to the expected reference.  | 
 boolean | 
compareAndSet(V expectedReference,
              V newReference,
              int expectedStamp,
              int newStamp)
Atomically sets the value of both the reference and stamp to the given update values if the current reference is == to the expected reference and the current stamp is equal to the expected stamp.  | 
 V | 
get(int[] stampHolder)
Returns the current values of both the reference and the stamp.  | 
 V | 
getReference()
Returns the current value of the reference.  | 
 int | 
getStamp()
Returns the current value of the stamp.  | 
 void | 
set(V newReference,
    int newStamp)
Unconditionally sets the value of both the reference and stamp.  | 
 boolean | 
weakCompareAndSet(V expectedReference,
                  V newReference,
                  int expectedStamp,
                  int newStamp)
Atomically sets the value of both the reference and stamp to the given update values if the current reference is == to the expected reference and the current stamp is equal to the expected stamp.  | 
| Methods inherited from class java.lang.Object | 
|---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Constructor Detail | 
|---|
public AtomicStampedReference(V initialRef,
                              int initialStamp)
initialRef - the initial referenceinitialStamp - the initial stamp| Method Detail | 
|---|
public V getReference()
public int getStamp()
public V get(int[] stampHolder)
stampHolder - an array of size of at least one.  On return,
 stampholder[0] will hold the value of the stamp.
public boolean weakCompareAndSet(V expectedReference,
                                 V newReference,
                                 int expectedStamp,
                                 int newStamp)
expectedReference - the expected value of the referencenewReference - the new value for the referenceexpectedStamp - the expected value of the stampnewStamp - the new value for the stamp
public boolean compareAndSet(V expectedReference,
                             V newReference,
                             int expectedStamp,
                             int newStamp)
expectedReference - the expected value of the referencenewReference - the new value for the referenceexpectedStamp - the expected value of the stampnewStamp - the new value for the stamp
public void set(V newReference,
                int newStamp)
newReference - the new value for the referencenewStamp - the new value for the stamp
public boolean attemptStamp(V expectedReference,
                            int newStamp)
expectedReference - the expected value of the referencenewStamp - the new value for the stamp
  | 
JavaTM 2 Platform Standard Ed. 5.0  | 
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
Copyright 2004 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.