Eliminate a redundant method call in HpackDynamicTable.add(...) (#10399)

Motivation:

The result of `header.size()` is already cached in `headerSize`. There is no need to call it again actually.

Modification:

Replace the second `header.size()` with `headerSize` directly.

Result:

Improve performance slightly.
This commit is contained in:
feijermu 2020-07-13 23:34:29 +08:00 committed by Norman Maurer
parent 47bbc590ee
commit eec46183f0
2 changed files with 25 additions and 1 deletions

View File

@ -109,7 +109,7 @@ final class HpackDynamicTable {
remove();
}
hpackHeaderFields[head++] = header;
size += header.size();
size += headerSize;
if (head == hpackHeaderFields.length) {
head = 0;
}

View File

@ -103,4 +103,28 @@ public class HpackDynamicTableTest {
assertEquals(0, table.length());
assertEquals(0, table.size());
}
@Test
public void testAdd() {
HpackDynamicTable table = new HpackDynamicTable(100);
assertEquals(0, table.size());
HpackHeaderField entry1 = new HpackHeaderField("foo", "bar"); //size:3+3+32=38
HpackHeaderField entry2 = new HpackHeaderField("hello", "world");
table.add(entry1); //success
assertEquals(entry1.size(), table.size());
table.setCapacity(32); //entry1 is removed from table
assertEquals(0, table.size());
assertEquals(0, table.length());
table.add(entry1); //fail quietly
assertEquals(0, table.size());
assertEquals(0, table.length());
table.setCapacity(64);
table.add(entry1); //success
assertEquals(entry1.size(), table.size());
assertEquals(1, table.length());
table.add(entry2); //entry2 is added, but entry1 is removed from table
assertEquals(entry2.size(), table.size());
assertEquals(1, table.length());
assertEquals(entry2, table.getEntry(1));
}
}