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:
Ludovic Orban 2020-05-13 09:14:59 +02:00 committed by GitHub
parent 86a40a07d6
commit f039becb97
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 7 additions and 2 deletions

View File

@ -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)