From 2482b1dc18217a5086b08df3416bc0f207dc3baf Mon Sep 17 00:00:00 2001 From: zzz Date: Mon, 29 Jan 2024 07:54:22 -0500 Subject: [PATCH] Crypto: More efficient enum lookup by code --- core/java/src/net/i2p/crypto/EncType.java | 17 +++++++++++------ core/java/src/net/i2p/crypto/SigType.java | 17 +++++++++++------ 2 files changed, 22 insertions(+), 12 deletions(-) diff --git a/core/java/src/net/i2p/crypto/EncType.java b/core/java/src/net/i2p/crypto/EncType.java index f05517ae08..dda7f0d821 100644 --- a/core/java/src/net/i2p/crypto/EncType.java +++ b/core/java/src/net/i2p/crypto/EncType.java @@ -2,9 +2,7 @@ import java.security.spec.AlgorithmParameterSpec; import java.security.spec.InvalidParameterSpecException; -import java.util.HashMap; import java.util.Locale; -import java.util.Map; import static net.i2p.crypto.x25519.spec.X25519Spec.X25519_SPEC; import net.i2p.data.Hash; @@ -156,18 +154,25 @@ public static boolean isAvailable(String stype) { return type.isAvailable(); } - private static final Map BY_CODE = new HashMap(); + private static final EncType[] BY_CODE; static { - for (EncType type : EncType.values()) { - if (BY_CODE.put(Integer.valueOf(type.getCode()), type) != null) + EncType[] values = values(); + int max = values[values.length - 1].getCode(); + BY_CODE = new EncType[max + 1]; + for (EncType type : values) { + int i = type.getCode(); + if (BY_CODE[i] != null) throw new IllegalStateException("Duplicate EncType code"); + BY_CODE[i] = type; } } /** @return null if not supported */ public static EncType getByCode(int code) { - return BY_CODE.get(Integer.valueOf(code)); + if (code < 0 || code >= BY_CODE.length) + return null; + return BY_CODE[code]; } /** diff --git a/core/java/src/net/i2p/crypto/SigType.java b/core/java/src/net/i2p/crypto/SigType.java index 7832c38604..afb96ac7cd 100644 --- a/core/java/src/net/i2p/crypto/SigType.java +++ b/core/java/src/net/i2p/crypto/SigType.java @@ -6,9 +6,7 @@ import java.security.Signature; import java.security.spec.AlgorithmParameterSpec; import java.security.spec.InvalidParameterSpecException; -import java.util.HashMap; import java.util.Locale; -import java.util.Map; import net.i2p.crypto.eddsa.spec.EdDSANamedCurveTable; import net.i2p.data.Hash; @@ -277,18 +275,25 @@ public static boolean isAvailable(String stype) { return type.isAvailable(); } - private static final Map BY_CODE = new HashMap(); + private static final SigType[] BY_CODE; static { - for (SigType type : SigType.values()) { - if (BY_CODE.put(Integer.valueOf(type.getCode()), type) != null) + SigType[] values = values(); + int max = values[values.length - 1].getCode(); + BY_CODE = new SigType[max + 1]; + for (SigType type : values) { + int i = type.getCode(); + if (BY_CODE[i] != null) throw new IllegalStateException("Duplicate SigType code"); + BY_CODE[i] = type; } } /** @return null if not supported */ public static SigType getByCode(int code) { - return BY_CODE.get(Integer.valueOf(code)); + if (code < 0 || code >= BY_CODE.length) + return null; + return BY_CODE[code]; } /**