From 6d7bed3431b6145d0950951550234e1806f5dd80 Mon Sep 17 00:00:00 2001 From: Guido Medina Date: Fri, 22 Apr 2016 09:34:56 +0100 Subject: [PATCH] TreeMap extra get operation removed. Motivation: Checking if a key exists on a TreeMap has a Big O of "log 2 N", doing it twice is not cheap. Modifications: Get the key instead which has the same cost and check if it is null. Result: Faster code due to one expensive operation removed. --- .../codec/spdy/DefaultSpdySettingsFrame.java | 50 +++++++------------ 1 file changed, 17 insertions(+), 33 deletions(-) diff --git a/codec-http/src/main/java/io/netty/handler/codec/spdy/DefaultSpdySettingsFrame.java b/codec-http/src/main/java/io/netty/handler/codec/spdy/DefaultSpdySettingsFrame.java index 94483cbb47..5097048601 100644 --- a/codec-http/src/main/java/io/netty/handler/codec/spdy/DefaultSpdySettingsFrame.java +++ b/codec-http/src/main/java/io/netty/handler/codec/spdy/DefaultSpdySettingsFrame.java @@ -36,18 +36,13 @@ public class DefaultSpdySettingsFrame implements SpdySettingsFrame { @Override public boolean isSet(int id) { - Integer key = Integer.valueOf(id); - return settingsMap.containsKey(key); + return settingsMap.containsKey(id); } @Override public int getValue(int id) { - Integer key = Integer.valueOf(id); - if (settingsMap.containsKey(key)) { - return settingsMap.get(key).getValue(); - } else { - return -1; - } + final Setting setting = settingsMap.get(id); + return setting != null ? setting.getValue() : -1; } @Override @@ -60,9 +55,9 @@ public class DefaultSpdySettingsFrame implements SpdySettingsFrame { if (id < 0 || id > SpdyCodecUtil.SPDY_SETTINGS_MAX_ID) { throw new IllegalArgumentException("Setting ID is not valid: " + id); } - Integer key = Integer.valueOf(id); - if (settingsMap.containsKey(key)) { - Setting setting = settingsMap.get(key); + final Integer key = Integer.valueOf(id); + final Setting setting = settingsMap.get(key); + if (setting != null) { setting.setValue(value); setting.setPersist(persistValue); setting.setPersisted(persisted); @@ -74,47 +69,36 @@ public class DefaultSpdySettingsFrame implements SpdySettingsFrame { @Override public SpdySettingsFrame removeValue(int id) { - Integer key = Integer.valueOf(id); - if (settingsMap.containsKey(key)) { - settingsMap.remove(key); - } + settingsMap.remove(id); return this; } @Override public boolean isPersistValue(int id) { - Integer key = Integer.valueOf(id); - if (settingsMap.containsKey(key)) { - return settingsMap.get(key).isPersist(); - } else { - return false; - } + final Setting setting = settingsMap.get(id); + return setting != null && setting.isPersist(); } @Override public SpdySettingsFrame setPersistValue(int id, boolean persistValue) { - Integer key = Integer.valueOf(id); - if (settingsMap.containsKey(key)) { - settingsMap.get(key).setPersist(persistValue); + final Setting setting = settingsMap.get(id); + if (setting != null) { + setting.setPersist(persistValue); } return this; } @Override public boolean isPersisted(int id) { - Integer key = Integer.valueOf(id); - if (settingsMap.containsKey(key)) { - return settingsMap.get(key).isPersisted(); - } else { - return false; - } + final Setting setting = settingsMap.get(id); + return setting != null && setting.isPersisted(); } @Override public SpdySettingsFrame setPersisted(int id, boolean persisted) { - Integer key = Integer.valueOf(id); - if (settingsMap.containsKey(key)) { - settingsMap.get(key).setPersisted(persisted); + final Setting setting = settingsMap.get(id); + if (setting != null) { + setting.setPersisted(persisted); } return this; }