On Mon, 7 Jul 2025 16:13:08 GMT, Andrew Haley <a...@openjdk.org> wrote:

> Neither `ScopedValue.orElse` nor `ScopedValue.orElseThrow` consult the cache 
> when searching for a binding. Neither do they update the cache when a binding 
> is found.
> While this issue does not affect spec compliance, it is surprising to users 
> that `x.orElse(other)` should be slower than `x.isBound ? x.get() : other`.

Can `get` and `slowGet` be refactored to use this `findBinding` too? That way 
we have just one piece of code accessing the cache, easier for long-term 
maintenance. `get` can probably become something like:


        var value = findBinding();
        if (value == Snapshot.NIL) {
            throw new NoSuchElementException("ScopedValue not bound");
        }
        return (T)value;


and remove `slowGet` altogether.

P.S. moved from inline comments, not really suitable for inline

-------------

PR Comment: https://git.openjdk.org/jdk/pull/26164#issuecomment-3045855108

Reply via email to