<div dir="ltr"><div dir="ltr" class="gmail_msg">Some users have expressed the need to have some sort of forEach operation that is performed where the Consumer is called while holding the lock for the given key and subsequently released after the Consumer operation completes.<div class="gmail_msg"><br class="gmail_msg"></div><div class="gmail_msg">Due to the nature of how streams work with retries and performing the operation on the primary owner, this works out quite well with forEach to be done in an efficient way.<br><br></div><div class="gmail_msg">The problem is that this only really works well with non tx and pessimistic tx. This obviously leaves out optimistic tx, which at first I was a little worried about. But after thinking about it more, this prelocking and optimistic tx don&#39;t really fit that well together anyways. So I am thinking whenever this operation is performed it would throw an exception not letting the user use this feature in optimistic transactions.<br><br></div><div class="gmail_msg">Another question is what does the API for this look like. I was debating between 3 options myself:<br><br></div><div class="gmail_msg">1. AdvancedCache.forEachWithLock(BiConsumer&lt;Cache, CacheEntry&lt;K, V&gt;&gt; consumer)<br></div><div class="gmail_msg"><br>This require the least amount of changes, however the user can&#39;t customize certain parameters that CacheStream currently provides (listed below - big one being filterKeys).<br><br></div><div class="gmail_msg">2. CacheStream.forEachWithLock(BiConsumer&lt;Cache, CacheEntry&lt;K, V&gt;&gt; consumer)<br></div><div class="gmail_msg"> <br>This method would only be allowed to be invoked on the Stream if no other intermediate operations were invoked, otherwise an exception would be thrown. This still gives us access to all of the CacheStream methods that aren&#39;t on the Stream interface (ie. sequentialDistribution, parallelDistribution, parallel, sequential, filterKeys, filterKeySegments, distributedBatchSize, disableRehashAware, timeout).<br></div><div class="gmail_msg"><br></div><div class="gmail_msg">3. LockedStream&lt;CacheEntry&lt;K, V&gt;&gt; AdvancedCache.lockedStream()<br><br></div><div class="gmail_msg">This requires the most changes, however the API would be the most explicit. In this case the LockedStream would only have the methods on it that are able to be invoked as noted above and forEach.<br><br></div><div class="gmail_msg">I personally feel that #3 might be the cleanest, but obviously requires adding more classes. Let me know what you guys think and if you think the optimistic exclusion is acceptable.<br><br></div><div class="gmail_msg">Thanks,<br></div><div class="gmail_msg"><br></div><div class="gmail_msg"> - Will<br></div></div></div>