Replace HashSet with ArrayList as that has two benefits: (#4871)
- ArrayList contains() + add() is faster than HashSet add() for small collections - A heap allocation of the iterator is required when iterating HashSet while iterating ArrayList can do with a stack allocation Signed-off-by: Ludovic Orban <lorban@bitronix.be>
This commit is contained in:
parent
86a40a07d6
commit
f039becb97
|
@ -21,6 +21,8 @@ package org.eclipse.jetty.http2;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
import java.util.ArrayDeque;
|
import java.util.ArrayDeque;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
import java.util.Deque;
|
import java.util.Deque;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
|
@ -47,7 +49,7 @@ public class HTTP2Flusher extends IteratingCallback implements Dumpable
|
||||||
private final Queue<WindowEntry> windows = new ArrayDeque<>();
|
private final Queue<WindowEntry> windows = new ArrayDeque<>();
|
||||||
private final Deque<Entry> entries = new ArrayDeque<>();
|
private final Deque<Entry> entries = new ArrayDeque<>();
|
||||||
private final Queue<Entry> pendingEntries = new ArrayDeque<>();
|
private final Queue<Entry> pendingEntries = new ArrayDeque<>();
|
||||||
private final Set<Entry> processedEntries = new HashSet<>();
|
private final Collection<Entry> processedEntries = new ArrayList<>();
|
||||||
private final HTTP2Session session;
|
private final HTTP2Session session;
|
||||||
private final ByteBufferPool.Lease lease;
|
private final ByteBufferPool.Lease lease;
|
||||||
private Throwable terminated;
|
private Throwable terminated;
|
||||||
|
@ -192,6 +194,9 @@ public class HTTP2Flusher extends IteratingCallback implements Dumpable
|
||||||
|
|
||||||
progress = true;
|
progress = true;
|
||||||
|
|
||||||
|
// We use ArrayList contains() + add() instead of HashSet add()
|
||||||
|
// because that is faster for collections of size up to 250 entries.
|
||||||
|
if (!processedEntries.contains(entry))
|
||||||
processedEntries.add(entry);
|
processedEntries.add(entry);
|
||||||
|
|
||||||
if (entry.getDataBytesRemaining() == 0)
|
if (entry.getDataBytesRemaining() == 0)
|
||||||
|
|
Loading…
Reference in New Issue