public class CASMutator<T> extends SpyObject
Example usage (reinventing incr):
// Get or create a client. MemcachedClient client=[...]; // Get a Transcoder. Transcodertc = new LongTranscoder(); // Get a mutator instance that uses that client. CASMutator<Long> mutator=new CASMutator<Long>(client, tc); // Get a mutation that knows what to do when a value is found. CASMutation<Long> mutation=new CASMutation<Long>() { public Long getNewValue(Long current) { return current + 1; } }; // Do a mutation. long currentValue=mutator.cas(someKey, 0L, 0, mutation);
Constructor and Description |
---|
CASMutator(MemcachedClientIF c,
Transcoder<T> tc)
Construct a CASMutator that uses the given client.
|
CASMutator(MemcachedClientIF c,
Transcoder<T> tc,
int maxTries)
Construct a CASMutator that uses the given client.
|
Modifier and Type | Method and Description |
---|---|
T |
cas(java.lang.String key,
T initial,
int initialExp,
CASMutation<T> m)
CAS a new value in for a key.
|
public CASMutator(MemcachedClientIF c, Transcoder<T> tc, int maxTries)
c
- the clienttc
- the Transcoder to usemaxTries
- the maximum number of attempts to get a CAS to succeedpublic CASMutator(MemcachedClientIF c, Transcoder<T> tc)
c
- the clienttc
- the Transcoder to usepublic T cas(java.lang.String key, T initial, int initialExp, CASMutation<T> m) throws java.lang.Exception
Note that if initial is null, this method will only update existing values.
key
- the key to be CASedinitial
- the value to use when the object is not cachedinitialExp
- the expiration time to use when initializingm
- the mutation to perform on an object if a value exists for the keyjava.lang.Exception
Copyright © 2006-2009 Dustin Sallings, 2009-2013 Couchbase, Inc.