ConditionalPut Class |
Namespace: Tangosol.Util.Processor
public class ConditionalPut : AbstractProcessor, IPortableObject
The ConditionalPut type exposes the following members.
Name | Description | |
---|---|---|
![]() | ConditionalPut |
Default constructor.
|
![]() | ConditionalPut(IFilter, Object) |
Construct a ConditionalPut that updates an entry with a
new value if and only if the filter applied to the entry
evaluates to true.
|
![]() | ConditionalPut(IFilter, Object, Boolean) |
Construct a ConditionalPut that updates an entry with a
new value if and only if the filter applied to the entry
evaluates to true.
|
Name | Description | |
---|---|---|
![]() | Equals |
Compare the ConditionalPut with another object to
determine equality.
(Overrides ObjectEquals(Object).) |
![]() | Finalize | Allows an object to try to free resources and perform other cleanup operations before it is reclaimed by garbage collection. (Inherited from Object.) |
![]() | GetHashCode |
Determine a hash value for the ConditionalPut object
according to the general GetHashCode
contract.
(Overrides ObjectGetHashCode.) |
![]() | GetType | Gets the Type of the current instance. (Inherited from Object.) |
![]() | MemberwiseClone | Creates a shallow copy of the current Object. (Inherited from Object.) |
![]() | Process |
Process an IInvocableCacheEntry.
(Overrides AbstractProcessorProcess(IInvocableCacheEntry).) |
![]() | ProcessAll |
Process a collection of IInvocableCacheEntry
objects.
(Overrides AbstractProcessorProcessAll(ICollection).) |
![]() | ReadExternal |
Restore the contents of a user type instance by reading its state
using the specified IPofReader object.
|
![]() | ToString |
Return a human-readable description for this
ConditionalPut.
(Overrides ObjectToString.) |
![]() | WriteExternal |
Save the contents of a POF user type instance by writing its
state using the specified IPofWriter object.
|
Name | Description | |
---|---|---|
![]() | m_filter |
The underlying filter.
|
![]() | m_return |
Specifies whether or not a return value is required.
|
![]() | m_value |
Specifies the new value to update an entry with.
|
While the ConditionalPut processing could be implemented via direct key-based IQueryCache operations, it is more efficient and enforces concurrency control without explicit locking.
IInvocableCache | IConcurrentCache |
---|---|
filter = PresentFilter.Instance; cache.Invoke(key, new ConditionalPut(filter, value)); | cache.Replace(key, value); |
filter = new NotFilter(PresentFilter.Instance); cache.Invoke(key, new ConditionalPut(filter, value)); | cache.PutIfAbsent(key, value); |
filter = new EqualsFilter(IdentityExtractor.Instance, valueOld); cache.Invoke(key, new ConditionalPut(filter, valueNew)); | cache.Replace(key, valueOld, valueNew); |
Obviously, using more specific, fine-tuned filters (rather than ones based on the IdentityExtractor may provide additional flexibility and efficiency allowing the put operation to be performed conditionally on values of specific attributes (or even calculations) instead of the entire object.