public class AddOperation extends AbstractPNCounterOperation implements MutatingOperation
PNCounter
.
The session consistency guarantees are provided by sending a last-observed
vector clock with each operation. The operation response will contain the
current replica vector clock.name
GENERIC_PARTITION_ID
Constructor and Description |
---|
AddOperation() |
AddOperation(String name,
long delta,
boolean getBeforeUpdate,
VectorClock observedClock)
Creates the addition operation.
|
Modifier and Type | Method and Description |
---|---|
int |
getId()
Returns type identifier for this class.
|
CRDTTimestampedLong |
getResponse()
Called if and only if
Operation.returnsResponse() returned true ,
shortly after Operation.run() returns. |
protected void |
readInternal(ObjectDataInput in) |
void |
run()
Runs the operation.
|
protected void |
writeInternal(ObjectDataOutput out) |
getFactoryId, getName, getServiceName, toString
afterRun, beforeRun, call, executedLocally, getCallerAddress, getCallerUuid, getCallId, getCallTimeout, getConnection, getInvocationTime, getLogger, getNodeEngine, getOperationResponseHandler, getPartitionId, getReplicaIndex, getService, getWaitTimeout, isUrgent, logError, onExecutionFailure, onInvocationException, onSetCallId, readData, requiresExplicitServiceName, returnsResponse, sendResponse, setCallerUuid, setNodeEngine, setOperationResponseHandler, setPartitionId, setReplicaIndex, setService, setServiceName, setValidateTarget, setWaitTimeout, toString, validatesTarget, writeData
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
readData, writeData
public AddOperation(String name, long delta, boolean getBeforeUpdate, VectorClock observedClock)
name
- the name of the PNCounterdelta
- the delta to add to the counter value, can be negativegetBeforeUpdate
- true
if the operation should return the
counter value before the addition, false
if it should return the value after the additionobservedClock
- previously observed vector clock, may be null
public AddOperation()
public void run() throws Exception
Operation
Operation.run()
or Operation.call()
method should be implemented; not both.
Runs after wait-support, supposed to do actual operationrun
in class Operation
Exception
Operation.call()
public CRDTTimestampedLong getResponse()
Operation
Operation.returnsResponse()
returned true
,
shortly after Operation.run()
returns.getResponse
in class Operation
protected void writeInternal(ObjectDataOutput out) throws IOException
writeInternal
in class AbstractPNCounterOperation
IOException
protected void readInternal(ObjectDataInput in) throws IOException
readInternal
in class AbstractPNCounterOperation
IOException
public int getId()
IdentifiedDataSerializable
getId
in interface IdentifiedDataSerializable
Copyright © 2020 Hazelcast, Inc.. All Rights Reserved.