Don't pollute FastThreadLocal for Threads with WeakHashMap if maxDelayedQueues == 0 (#9722)
Motivation: If maxDelayedQueues == 0 we should never put any WeakHashMap into the FastThreadLocal for a Thread. Modifications: Check if maxDelayedQueues == 0 and if so return directly. This will ensure we never call FastThreadLocal.initialValue() in this case Result: Less overhead / memory usage when maxDelayedQueues == 0
This commit is contained in:
parent
d4d81ac94c
commit
dc104de503
@ -619,6 +619,10 @@ public abstract class Recycler<T> {
|
||||
}
|
||||
|
||||
private void pushLater(DefaultHandle<?> item, Thread thread) {
|
||||
if (maxDelayedQueues == 0) {
|
||||
// We don't support recycling across threads and should just drop the item on the floor.
|
||||
return;
|
||||
}
|
||||
// we don't want to have a ref to the queue as the value in our weak map
|
||||
// so we null it out; to ensure there are no races with restoring it later
|
||||
// we impose a memory ordering here (no-op on x86)
|
||||
|
Loading…
Reference in New Issue
Block a user