ConditionalRemove Class |
Namespace: Tangosol.Util.Processor
public class ConditionalRemove : AbstractProcessor, IPortableObject
The ConditionalRemove type exposes the following members.
Name | Description | |
---|---|---|
![]() | ConditionalRemove |
Default constructor.
|
![]() | ConditionalRemove(IFilter) |
Construct a ConditionalRemove processor that removes an
IInvocableCacheEntry if and only if the filter
applied to the entry evaluates to true.
|
![]() | ConditionalRemove(IFilter, Boolean) |
Construct a ConditionalRemove processor that removes an
IInvocableCacheEntry if and only if the filter
applied to the entry evaluates to true.
|
Name | Description | |
---|---|---|
![]() | Equals |
Compare the ConditionalRemove 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 ConditionalRemove 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
ConditionalRemove.
(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.
|
While the ConditionalRemove processing could be implemented via direct key-based IQueryCache operations, it is more efficient and enforces concurrency control without explicit locking.
For example, the following operations are functionally similar, but the IInvocableDictionary versions (a) perform significantly better for partitioned caches; (b) provide all necessary concurrency control (which is ommited from the IQueryCache examples):
IInvocableCache | IQueryCache |
---|---|
cache.invoke(key, new ConditionalRemove(filter)); | if (filter.Evaluate(cache[key]) cache.Remove(key); |
cache.InvokeAll(colKeys, new ConditionalRemove(filter)); | foreach (object key in colKeys) if (filter.Evaluate(cache.[key]) cache.Remove(key); |
cache.InvokeAll(filter1, new ConditionalRemove(filter2); | foreach (object key in cache.GetKeys(filter1)) if (filter2.Evaluate(cache[key]) cache.Remove(key); |
cache.InvokeAll(filter, new ConditionalRemove(AlwaysFilter.INSTANCE)); | ICollection colKeys = cache.GetKeys(filter); cache.Keys.RemoveAll(colKeys); |