From e01cd7c3ed923cd19509fc972ba6e4aa2991289f Mon Sep 17 00:00:00 2001 From: XenoAmess Date: Thu, 9 Jun 2022 01:50:54 +0000 Subject: [PATCH] 8284780: Need methods to create pre-sized HashSet and LinkedHashSet Reviewed-by: naoto, bpb, dfuchs, ascarpino --- .../sun/crypto/provider/PBEKeyFactory.java | 2 +- .../classes/java/io/ObjectStreamClass.java | 2 +- .../invoke/InnerClassLambdaMetafactory.java | 2 +- .../classes/java/nio/charset/Charset.java | 2 +- .../java/time/format/DecimalStyle.java | 2 +- .../share/classes/java/util/Calendar.java | 9 +-- .../share/classes/java/util/HashSet.java | 25 +++++++ .../classes/java/util/LinkedHashSet.java | 27 ++++++- .../jdk/internal/module/ModuleInfo.java | 6 +- .../www/protocol/http/HttpURLConnection.java | 2 +- .../AsynchronousServerSocketChannelImpl.java | 2 +- .../nio/ch/AsynchronousSocketChannelImpl.java | 2 +- .../classes/sun/nio/fs/AbstractPoller.java | 2 +- .../sun/nio/fs/PollingWatchService.java | 2 +- .../classes/sun/security/pkcs/PKCS7.java | 2 +- .../provider/certpath/ConstraintsChecker.java | 2 +- .../provider/certpath/ForwardBuilder.java | 4 +- .../provider/certpath/KeyChecker.java | 2 +- .../provider/certpath/PolicyChecker.java | 4 +- .../sun/security/ssl/CertificateMessage.java | 2 +- .../security/ssl/SunX509KeyManagerImpl.java | 2 +- .../util/locale/InternalLocaleBuilder.java | 2 +- .../net/http/websocket/OpeningHandshake.java | 2 +- .../sun/rmi/transport/tcp/TCPEndpoint.java | 2 +- .../classes/jdk/nio/zipfs/ZipFileSystem.java | 2 +- .../UnreferencedRAFClosesFd.java | 2 +- .../System/MacEncoding/TestFileEncoding.java | 2 +- .../Format/common/FormatIteratorTest.java | 2 +- .../java/util/HashMap/WhiteBoxResizeTest.java | 75 ++++++++++++++++--- 29 files changed, 147 insertions(+), 47 deletions(-) diff --git a/src/java.base/share/classes/com/sun/crypto/provider/PBEKeyFactory.java b/src/java.base/share/classes/com/sun/crypto/provider/PBEKeyFactory.java index ed09fe94118..dea4fd82a48 100644 --- a/src/java.base/share/classes/com/sun/crypto/provider/PBEKeyFactory.java +++ b/src/java.base/share/classes/com/sun/crypto/provider/PBEKeyFactory.java @@ -56,7 +56,7 @@ abstract class PBEKeyFactory extends SecretKeyFactorySpi { } static { - validTypes = new HashSet<>(17); + validTypes = HashSet.newHashSet(17); validTypes.add("PBEWithMD5AndDES".toUpperCase(Locale.ENGLISH)); validTypes.add("PBEWithSHA1AndDESede".toUpperCase(Locale.ENGLISH)); validTypes.add("PBEWithSHA1AndRC2_40".toUpperCase(Locale.ENGLISH)); diff --git a/src/java.base/share/classes/java/io/ObjectStreamClass.java b/src/java.base/share/classes/java/io/ObjectStreamClass.java index 9a3f96d0785..6cadda0cd2d 100644 --- a/src/java.base/share/classes/java/io/ObjectStreamClass.java +++ b/src/java.base/share/classes/java/io/ObjectStreamClass.java @@ -1648,7 +1648,7 @@ public final class ObjectStreamClass implements Serializable { ObjectStreamField[] boundFields = new ObjectStreamField[serialPersistentFields.length]; - Set fieldNames = new HashSet<>(serialPersistentFields.length); + Set fieldNames = HashSet.newHashSet(serialPersistentFields.length); for (int i = 0; i < serialPersistentFields.length; i++) { ObjectStreamField spf = serialPersistentFields[i]; diff --git a/src/java.base/share/classes/java/lang/invoke/InnerClassLambdaMetafactory.java b/src/java.base/share/classes/java/lang/invoke/InnerClassLambdaMetafactory.java index 30014e1799a..89f794ad180 100644 --- a/src/java.base/share/classes/java/lang/invoke/InnerClassLambdaMetafactory.java +++ b/src/java.base/share/classes/java/lang/invoke/InnerClassLambdaMetafactory.java @@ -310,7 +310,7 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*; interfaceNames = new String[]{interfaceName}; } else { // Assure no duplicate interfaces (ClassFormatError) - Set itfs = new LinkedHashSet<>(altInterfaces.length + 1); + Set itfs = LinkedHashSet.newLinkedHashSet(altInterfaces.length + 1); itfs.add(interfaceName); for (Class i : altInterfaces) { itfs.add(i.getName().replace('.', '/')); diff --git a/src/java.base/share/classes/java/nio/charset/Charset.java b/src/java.base/share/classes/java/nio/charset/Charset.java index dd03bc24b78..da62c13b881 100644 --- a/src/java.base/share/classes/java/nio/charset/Charset.java +++ b/src/java.base/share/classes/java/nio/charset/Charset.java @@ -718,7 +718,7 @@ public abstract class Charset if (aliasSet != null) return aliasSet; int n = aliases.length; - HashSet hs = new HashSet<>(n); + HashSet hs = HashSet.newHashSet(n); for (int i = 0; i < n; i++) hs.add(aliases[i]); aliasSet = Collections.unmodifiableSet(hs); diff --git a/src/java.base/share/classes/java/time/format/DecimalStyle.java b/src/java.base/share/classes/java/time/format/DecimalStyle.java index 384da33243b..9440847c7c3 100644 --- a/src/java.base/share/classes/java/time/format/DecimalStyle.java +++ b/src/java.base/share/classes/java/time/format/DecimalStyle.java @@ -123,7 +123,7 @@ public final class DecimalStyle { */ public static Set getAvailableLocales() { Locale[] l = DecimalFormatSymbols.getAvailableLocales(); - Set locales = new HashSet<>(l.length); + Set locales = HashSet.newHashSet(l.length); Collections.addAll(locales, l); return locales; } diff --git a/src/java.base/share/classes/java/util/Calendar.java b/src/java.base/share/classes/java/util/Calendar.java index 5a31aade918..12e13327b3b 100644 --- a/src/java.base/share/classes/java/util/Calendar.java +++ b/src/java.base/share/classes/java/util/Calendar.java @@ -2640,14 +2640,7 @@ public abstract class Calendar implements Serializable, Cloneable, Comparable SET; - static { - Set set = new HashSet<>(3); - set.add("gregory"); - set.add("buddhist"); - set.add("japanese"); - SET = Collections.unmodifiableSet(set); - } + private static final Set SET = Set.of("gregory", "buddhist", "japanese"); private AvailableCalendarTypes() { } } diff --git a/src/java.base/share/classes/java/util/HashSet.java b/src/java.base/share/classes/java/util/HashSet.java index 601401ca669..04dde3424f1 100644 --- a/src/java.base/share/classes/java/util/HashSet.java +++ b/src/java.base/share/classes/java/util/HashSet.java @@ -125,6 +125,10 @@ public class HashSet * Constructs a new, empty set; the backing {@code HashMap} instance has * the specified initial capacity and the specified load factor. * + * @apiNote + * To create a {@code HashSet} with an initial capacity that accommodates + * an expected number of elements, use {@link #newHashSet(int) newHashSet}. + * * @param initialCapacity the initial capacity of the hash map * @param loadFactor the load factor of the hash map * @throws IllegalArgumentException if the initial capacity is less @@ -138,6 +142,10 @@ public class HashSet * Constructs a new, empty set; the backing {@code HashMap} instance has * the specified initial capacity and default load factor (0.75). * + * @apiNote + * To create a {@code HashSet} with an initial capacity that accommodates + * an expected number of elements, use {@link #newHashSet(int) newHashSet}. + * * @param initialCapacity the initial capacity of the hash table * @throws IllegalArgumentException if the initial capacity is less * than zero @@ -372,4 +380,21 @@ public class HashSet public T[] toArray(T[] a) { return map.keysToArray(map.prepareArray(a)); } + + /** + * Creates a new, empty HashSet suitable for the expected number of elements. + * The returned set uses the default load factor of 0.75, and its initial capacity is + * generally large enough so that the expected number of elements can be added + * without resizing the set. + * + * @param numElements the expected number of elements + * @param the type of elements maintained by the new set + * @return the newly created set + * @throws IllegalArgumentException if numElements is negative + * @since 19 + */ + public static HashSet newHashSet(int numElements) { + return new HashSet<>(HashMap.calculateHashMapCapacity(numElements)); + } + } diff --git a/src/java.base/share/classes/java/util/LinkedHashSet.java b/src/java.base/share/classes/java/util/LinkedHashSet.java index e7c7c3867e1..913fe7ef01f 100644 --- a/src/java.base/share/classes/java/util/LinkedHashSet.java +++ b/src/java.base/share/classes/java/util/LinkedHashSet.java @@ -126,6 +126,10 @@ public class LinkedHashSet * Constructs a new, empty linked hash set with the specified initial * capacity and load factor. * + * @apiNote + * To create a {@code LinkedHashSet} with an initial capacity that accommodates + * an expected number of elements, use {@link #newLinkedHashSet(int) newLinkedHashSet}. + * * @param initialCapacity the initial capacity of the linked hash set * @param loadFactor the load factor of the linked hash set * @throws IllegalArgumentException if the initial capacity is less @@ -139,6 +143,10 @@ public class LinkedHashSet * Constructs a new, empty linked hash set with the specified initial * capacity and the default load factor (0.75). * + * @apiNote + * To create a {@code LinkedHashSet} with an initial capacity that accommodates + * an expected number of elements, use {@link #newLinkedHashSet(int) newLinkedHashSet}. + * * @param initialCapacity the initial capacity of the LinkedHashSet * @throws IllegalArgumentException if the initial capacity is less * than zero @@ -166,7 +174,7 @@ public class LinkedHashSet * @throws NullPointerException if the specified collection is null */ public LinkedHashSet(Collection c) { - super(Math.max(2*c.size(), 11), .75f, true); + super(HashMap.calculateHashMapCapacity(Math.max(c.size(), 12)), .75f, true); addAll(c); } @@ -193,4 +201,21 @@ public class LinkedHashSet public Spliterator spliterator() { return Spliterators.spliterator(this, Spliterator.DISTINCT | Spliterator.ORDERED); } + + /** + * Creates a new, empty LinkedHashSet suitable for the expected number of elements. + * The returned set uses the default load factor of 0.75, and its initial capacity is + * generally large enough so that the expected number of elements can be added + * without resizing the set. + * + * @param numElements the expected number of elements + * @param the type of elements maintained by the new set + * @return the newly created set + * @throws IllegalArgumentException if numElements is negative + * @since 19 + */ + public static LinkedHashSet newLinkedHashSet(int numElements) { + return new LinkedHashSet<>(HashMap.calculateHashMapCapacity(numElements)); + } + } diff --git a/src/java.base/share/classes/jdk/internal/module/ModuleInfo.java b/src/java.base/share/classes/jdk/internal/module/ModuleInfo.java index 91507a1b170..3a188ee8758 100644 --- a/src/java.base/share/classes/jdk/internal/module/ModuleInfo.java +++ b/src/java.base/share/classes/jdk/internal/module/ModuleInfo.java @@ -446,7 +446,7 @@ public final class ModuleInfo { int exports_to_count = in.readUnsignedShort(); if (exports_to_count > 0) { - Set targets = new HashSet<>(exports_to_count); + Set targets = HashSet.newHashSet(exports_to_count); for (int j=0; j 0) { - Set targets = new HashSet<>(open_to_count); + Set targets = HashSet.newHashSet(open_to_count); for (int j=0; j packages = new HashSet<>(package_count); + Set packages = HashSet.newHashSet(package_count); for (int i=0; i(restrictedHeaders.length); + restrictedHeaderSet = HashSet.newHashSet(restrictedHeaders.length); for (int i=0; i < restrictedHeaders.length; i++) { restrictedHeaderSet.add(restrictedHeaders[i].toLowerCase()); } diff --git a/src/java.base/share/classes/sun/nio/ch/AsynchronousServerSocketChannelImpl.java b/src/java.base/share/classes/sun/nio/ch/AsynchronousServerSocketChannelImpl.java index d17dda4c615..8ce7ef1f986 100644 --- a/src/java.base/share/classes/sun/nio/ch/AsynchronousServerSocketChannelImpl.java +++ b/src/java.base/share/classes/sun/nio/ch/AsynchronousServerSocketChannelImpl.java @@ -230,7 +230,7 @@ abstract class AsynchronousServerSocketChannelImpl static final Set> defaultOptions = defaultOptions(); private static Set> defaultOptions() { - HashSet> set = new HashSet<>(2); + HashSet> set = HashSet.newHashSet(2); set.add(StandardSocketOptions.SO_RCVBUF); set.add(StandardSocketOptions.SO_REUSEADDR); if (Net.isReusePortAvailable()) { diff --git a/src/java.base/share/classes/sun/nio/ch/AsynchronousSocketChannelImpl.java b/src/java.base/share/classes/sun/nio/ch/AsynchronousSocketChannelImpl.java index 4bae4219b97..9c07dc47cd2 100644 --- a/src/java.base/share/classes/sun/nio/ch/AsynchronousSocketChannelImpl.java +++ b/src/java.base/share/classes/sun/nio/ch/AsynchronousSocketChannelImpl.java @@ -503,7 +503,7 @@ abstract class AsynchronousSocketChannelImpl static final Set> defaultOptions = defaultOptions(); private static Set> defaultOptions() { - HashSet> set = new HashSet<>(5); + HashSet> set = HashSet.newHashSet(5); set.add(StandardSocketOptions.SO_SNDBUF); set.add(StandardSocketOptions.SO_RCVBUF); set.add(StandardSocketOptions.SO_KEEPALIVE); diff --git a/src/java.base/share/classes/sun/nio/fs/AbstractPoller.java b/src/java.base/share/classes/sun/nio/fs/AbstractPoller.java index 7e7ab2cc0d0..d2cd7217942 100644 --- a/src/java.base/share/classes/sun/nio/fs/AbstractPoller.java +++ b/src/java.base/share/classes/sun/nio/fs/AbstractPoller.java @@ -105,7 +105,7 @@ abstract class AbstractPoller implements Runnable { // validate arguments before request to poller if (dir == null) throw new NullPointerException(); - Set> eventSet = new HashSet<>(events.length); + Set> eventSet = HashSet.newHashSet(events.length); for (WatchEvent.Kind event: events) { // standard events if (event == StandardWatchEventKinds.ENTRY_CREATE || diff --git a/src/java.base/share/classes/sun/nio/fs/PollingWatchService.java b/src/java.base/share/classes/sun/nio/fs/PollingWatchService.java index 665de905a6b..72166700e7c 100644 --- a/src/java.base/share/classes/sun/nio/fs/PollingWatchService.java +++ b/src/java.base/share/classes/sun/nio/fs/PollingWatchService.java @@ -95,7 +95,7 @@ class PollingWatchService throws IOException { // check events - CCE will be thrown if there are invalid elements - final Set> eventSet = new HashSet<>(events.length); + final Set> eventSet = HashSet.newHashSet(events.length); for (WatchEvent.Kind event: events) { // standard events if (event == StandardWatchEventKinds.ENTRY_CREATE || diff --git a/src/java.base/share/classes/sun/security/pkcs/PKCS7.java b/src/java.base/share/classes/sun/security/pkcs/PKCS7.java index da6d1687a6d..7de2c056de7 100644 --- a/src/java.base/share/classes/sun/security/pkcs/PKCS7.java +++ b/src/java.base/share/classes/sun/security/pkcs/PKCS7.java @@ -514,7 +514,7 @@ public class PKCS7 { // CRLs (optional) if (crls != null && crls.length != 0) { // cast to X509CRLImpl[] since X509CRLImpl implements DerEncoder - Set implCRLs = new HashSet<>(crls.length); + Set implCRLs = HashSet.newHashSet(crls.length); for (X509CRL crl: crls) { if (crl instanceof X509CRLImpl) implCRLs.add((X509CRLImpl) crl); diff --git a/src/java.base/share/classes/sun/security/provider/certpath/ConstraintsChecker.java b/src/java.base/share/classes/sun/security/provider/certpath/ConstraintsChecker.java index 00d67de5a07..63cc688e8a6 100644 --- a/src/java.base/share/classes/sun/security/provider/certpath/ConstraintsChecker.java +++ b/src/java.base/share/classes/sun/security/provider/certpath/ConstraintsChecker.java @@ -92,7 +92,7 @@ class ConstraintsChecker extends PKIXCertPathChecker { @Override public Set getSupportedExtensions() { if (supportedExts == null) { - supportedExts = new HashSet(2); + supportedExts = HashSet.newHashSet(2); supportedExts.add(BasicConstraints_Id.toString()); supportedExts.add(NameConstraints_Id.toString()); supportedExts = Collections.unmodifiableSet(supportedExts); diff --git a/src/java.base/share/classes/sun/security/provider/certpath/ForwardBuilder.java b/src/java.base/share/classes/sun/security/provider/certpath/ForwardBuilder.java index fdc916a46af..644ae388dd0 100644 --- a/src/java.base/share/classes/sun/security/provider/certpath/ForwardBuilder.java +++ b/src/java.base/share/classes/sun/security/provider/certpath/ForwardBuilder.java @@ -81,8 +81,8 @@ final class ForwardBuilder extends Builder { // populate sets of trusted certificates and subject DNs trustAnchors = buildParams.trustAnchors(); - trustedCerts = new HashSet(trustAnchors.size()); - trustedSubjectDNs = new HashSet(trustAnchors.size()); + trustedCerts = HashSet.newHashSet(trustAnchors.size()); + trustedSubjectDNs = HashSet.newHashSet(trustAnchors.size()); for (TrustAnchor anchor : trustAnchors) { X509Certificate trustedCert = anchor.getTrustedCert(); if (trustedCert != null) { diff --git a/src/java.base/share/classes/sun/security/provider/certpath/KeyChecker.java b/src/java.base/share/classes/sun/security/provider/certpath/KeyChecker.java index 2d45d956a8f..ce108e4ae28 100644 --- a/src/java.base/share/classes/sun/security/provider/certpath/KeyChecker.java +++ b/src/java.base/share/classes/sun/security/provider/certpath/KeyChecker.java @@ -85,7 +85,7 @@ class KeyChecker extends PKIXCertPathChecker { @Override public Set getSupportedExtensions() { if (supportedExts == null) { - supportedExts = new HashSet(3); + supportedExts = HashSet.newHashSet(3); supportedExts.add(KeyUsage_Id.toString()); supportedExts.add(ExtendedKeyUsage_Id.toString()); supportedExts.add(SubjectAlternativeName_Id.toString()); diff --git a/src/java.base/share/classes/sun/security/provider/certpath/PolicyChecker.java b/src/java.base/share/classes/sun/security/provider/certpath/PolicyChecker.java index f6f69c4c57f..ce66692d421 100644 --- a/src/java.base/share/classes/sun/security/provider/certpath/PolicyChecker.java +++ b/src/java.base/share/classes/sun/security/provider/certpath/PolicyChecker.java @@ -93,7 +93,7 @@ class PolicyChecker extends PKIXCertPathChecker { if (initialPolicies.isEmpty()) { // if no initialPolicies are specified by user, set // initPolicies to be anyPolicy by default - this.initPolicies = new HashSet(1); + this.initPolicies = HashSet.newHashSet(1); this.initPolicies.add(ANY_POLICY); } else { this.initPolicies = new HashSet(initialPolicies); @@ -154,7 +154,7 @@ class PolicyChecker extends PKIXCertPathChecker { @Override public Set getSupportedExtensions() { if (supportedExts == null) { - supportedExts = new HashSet(4); + supportedExts = HashSet.newHashSet(4); supportedExts.add(CertificatePolicies_Id.toString()); supportedExts.add(PolicyMappings_Id.toString()); supportedExts.add(PolicyConstraints_Id.toString()); diff --git a/src/java.base/share/classes/sun/security/ssl/CertificateMessage.java b/src/java.base/share/classes/sun/security/ssl/CertificateMessage.java index 5921b7cfca5..83cfb43d0c1 100644 --- a/src/java.base/share/classes/sun/security/ssl/CertificateMessage.java +++ b/src/java.base/share/classes/sun/security/ssl/CertificateMessage.java @@ -573,7 +573,7 @@ final class CertificateMessage { if ((subAltDnsName != null) && !subAltDnsName.isEmpty()) { if (subAltDnsNames == null) { subAltDnsNames = - new HashSet<>(subjectAltNames.size()); + HashSet.newHashSet(subjectAltNames.size()); } subAltDnsNames.add(subAltDnsName); } diff --git a/src/java.base/share/classes/sun/security/ssl/SunX509KeyManagerImpl.java b/src/java.base/share/classes/sun/security/ssl/SunX509KeyManagerImpl.java index 22a4d68ed85..e9397cabb48 100644 --- a/src/java.base/share/classes/sun/security/ssl/SunX509KeyManagerImpl.java +++ b/src/java.base/share/classes/sun/security/ssl/SunX509KeyManagerImpl.java @@ -110,7 +110,7 @@ final class SunX509KeyManagerImpl extends X509ExtendedKeyManager { // assert privateKey and certificates != null this.privateKey = privateKey; this.certificates = certificates; - this.issuerX500Principals = new HashSet<>(certificates.length); + this.issuerX500Principals = HashSet.newHashSet(certificates.length); for (X509Certificate certificate : certificates) { issuerX500Principals.add(certificate.getIssuerX500Principal()); } diff --git a/src/java.base/share/classes/sun/util/locale/InternalLocaleBuilder.java b/src/java.base/share/classes/sun/util/locale/InternalLocaleBuilder.java index 252d369e4eb..894a49e8efe 100644 --- a/src/java.base/share/classes/sun/util/locale/InternalLocaleBuilder.java +++ b/src/java.base/share/classes/sun/util/locale/InternalLocaleBuilder.java @@ -313,7 +313,7 @@ public final class InternalLocaleBuilder { clearExtensions(); if (!LocaleUtils.isEmpty(bcpExtensions)) { - Set done = new HashSet<>(bcpExtensions.size()); + Set done = HashSet.newHashSet(bcpExtensions.size()); for (String bcpExt : bcpExtensions) { CaseInsensitiveChar key = new CaseInsensitiveChar(bcpExt); // ignore duplicates diff --git a/src/java.net.http/share/classes/jdk/internal/net/http/websocket/OpeningHandshake.java b/src/java.net.http/share/classes/jdk/internal/net/http/websocket/OpeningHandshake.java index dd60bd621b7..f88ec774dc0 100644 --- a/src/java.net.http/share/classes/jdk/internal/net/http/websocket/OpeningHandshake.java +++ b/src/java.net.http/share/classes/jdk/internal/net/http/websocket/OpeningHandshake.java @@ -148,7 +148,7 @@ public class OpeningHandshake { private static Collection createRequestSubprotocols( Collection subprotocols) { - LinkedHashSet sp = new LinkedHashSet<>(subprotocols.size(), 1); + LinkedHashSet sp = LinkedHashSet.newLinkedHashSet(subprotocols.size()); for (String s : subprotocols) { if (s.trim().isEmpty() || !isValidName(s)) { throw illegal("Bad subprotocol syntax: " + s); diff --git a/src/java.rmi/share/classes/sun/rmi/transport/tcp/TCPEndpoint.java b/src/java.rmi/share/classes/sun/rmi/transport/tcp/TCPEndpoint.java index f261e367071..6365b1e846d 100644 --- a/src/java.rmi/share/classes/sun/rmi/transport/tcp/TCPEndpoint.java +++ b/src/java.rmi/share/classes/sun/rmi/transport/tcp/TCPEndpoint.java @@ -384,7 +384,7 @@ public class TCPEndpoint implements Endpoint { Set s; synchronized (localEndpoints) { // presize s to number of localEndpoints - s = new HashSet(localEndpoints.size()); + s = HashSet.newHashSet(localEndpoints.size()); for (LinkedList epList : localEndpoints.values()) { /* * Each local endpoint has its transport added to s. diff --git a/src/jdk.zipfs/share/classes/jdk/nio/zipfs/ZipFileSystem.java b/src/jdk.zipfs/share/classes/jdk/nio/zipfs/ZipFileSystem.java index e67a375ae19..5adbd80f727 100644 --- a/src/jdk.zipfs/share/classes/jdk/nio/zipfs/ZipFileSystem.java +++ b/src/jdk.zipfs/share/classes/jdk/nio/zipfs/ZipFileSystem.java @@ -3309,7 +3309,7 @@ class ZipFileSystem extends FileSystem { public Optional> storedPermissions() { Set perms = null; if (posixPerms != -1) { - perms = new HashSet<>(PosixFilePermission.values().length); + perms = HashSet.newHashSet(PosixFilePermission.values().length); for (PosixFilePermission perm : PosixFilePermission.values()) { if ((posixPerms & ZipUtils.permToFlag(perm)) != 0) { perms.add(perm); diff --git a/test/jdk/java/io/RandomAccessFile/UnreferencedRAFClosesFd.java b/test/jdk/java/io/RandomAccessFile/UnreferencedRAFClosesFd.java index 05b84b4b227..c5b73a07c7d 100644 --- a/test/jdk/java/io/RandomAccessFile/UnreferencedRAFClosesFd.java +++ b/test/jdk/java/io/RandomAccessFile/UnreferencedRAFClosesFd.java @@ -81,7 +81,7 @@ public class UnreferencedRAFClosesFd { // Prepare to wait for FOS, FD, Cleanup to be reclaimed ReferenceQueue queue = new ReferenceQueue<>(); - HashSet> pending = new HashSet<>(3); + HashSet> pending = HashSet.newHashSet(3); pending.add(new WeakReference<>(cleanup, queue)); pending.add(new WeakReference<>(raf, queue)); pending.add(new WeakReference<>(fd, queue)); diff --git a/test/jdk/java/lang/System/MacEncoding/TestFileEncoding.java b/test/jdk/java/lang/System/MacEncoding/TestFileEncoding.java index 7055aef937e..bd5227a9b3d 100644 --- a/test/jdk/java/lang/System/MacEncoding/TestFileEncoding.java +++ b/test/jdk/java/lang/System/MacEncoding/TestFileEncoding.java @@ -57,7 +57,7 @@ public class TestFileEncoding { private String expectedEncoding; // Expected value for file.encoding private String langVar = null; // Value to set for LANG, etc - private static Set envToRm = new HashSet<>(3); + private static Set envToRm = HashSet.newHashSet(3); static { // Take these vars out of the test's run environment, possibly adding // our own value back in. diff --git a/test/jdk/java/text/Format/common/FormatIteratorTest.java b/test/jdk/java/text/Format/common/FormatIteratorTest.java index fede7df2012..b6654a74c5b 100644 --- a/test/jdk/java/text/Format/common/FormatIteratorTest.java +++ b/test/jdk/java/text/Format/common/FormatIteratorTest.java @@ -434,7 +434,7 @@ public class FormatIteratorTest extends IntlTest { } public Set makeAttributes(List names) { - Set set = new HashSet<>(Math.max(1, names.size())); + Set set = HashSet.newHashSet(names.size()); for (int counter = 0; counter < names.size(); counter++) { set.add(makeAttribute((String)names.get(counter))); diff --git a/test/jdk/java/util/HashMap/WhiteBoxResizeTest.java b/test/jdk/java/util/HashMap/WhiteBoxResizeTest.java index f669437add9..e5dd3743605 100644 --- a/test/jdk/java/util/HashMap/WhiteBoxResizeTest.java +++ b/test/jdk/java/util/HashMap/WhiteBoxResizeTest.java @@ -29,13 +29,16 @@ import java.lang.invoke.MethodHandle; import java.lang.invoke.MethodHandles; import java.lang.invoke.MethodType; import java.lang.invoke.VarHandle; +import java.lang.reflect.Field; import java.util.AbstractMap; import java.util.AbstractSet; import java.util.ArrayList; import java.util.Arrays; import java.util.HashMap; +import java.util.HashSet; import java.util.Iterator; import java.util.LinkedHashMap; +import java.util.LinkedHashSet; import java.util.List; import java.util.Map; import java.util.Set; @@ -48,7 +51,7 @@ import static org.testng.Assert.assertNull; /* * @test - * @bug 8186958 8210280 8281631 8285386 + * @bug 8186958 8210280 8281631 8285386 8284780 * @modules java.base/java.util:open * @summary White box tests for HashMap-related internals around table sizing * @run testng/othervm -Xmx2g WhiteBoxResizeTest @@ -58,6 +61,7 @@ public class WhiteBoxResizeTest { final MethodHandle TABLE_SIZE_FOR; final VarHandle HM_TABLE; final VarHandle WHM_TABLE; + final VarHandle HS_MAP; public WhiteBoxResizeTest() throws ReflectiveOperationException { MethodHandles.Lookup hmlookup = MethodHandles.privateLookupIn(HashMap.class, MethodHandles.lookup()); @@ -67,6 +71,9 @@ public class WhiteBoxResizeTest { MethodHandles.Lookup whmlookup = MethodHandles.privateLookupIn(WeakHashMap.class, MethodHandles.lookup()); WHM_TABLE = whmlookup.unreflectVarHandle(WeakHashMap.class.getDeclaredField("table")); + + MethodHandles.Lookup hslookup = MethodHandles.privateLookupIn(HashSet.class, MethodHandles.lookup()); + HS_MAP = hslookup.unreflectVarHandle(HashSet.class.getDeclaredField("map")); } /* @@ -328,15 +335,17 @@ public class WhiteBoxResizeTest { Object[] rsc(String label, int size, int expectedCapacity, - Supplier> supplier) { + Supplier supplier) { return new Object[]{label, size, expectedCapacity, supplier}; } List genRequestedSizeCases(int size, int cap) { return Arrays.asList( - rsc("rshm", size, cap, () -> HashMap.newHashMap(size)), - rsc("rslm", size, cap, () -> LinkedHashMap.newLinkedHashMap(size)), - rsc("rswm", size, cap, () -> WeakHashMap.newWeakHashMap(size)) + rsc("rshm", size, cap, () -> new MapCapacitiable(HashMap.newHashMap(size))), + rsc("rslm", size, cap, () -> new MapCapacitiable(LinkedHashMap.newLinkedHashMap(size))), + rsc("rswm", size, cap, () -> new MapCapacitiable(WeakHashMap.newWeakHashMap(size))), + rsc("rshs", size, cap, () -> new SetCapacitiable(HashSet.newHashSet(size))), + rsc("rsls", size, cap, () -> new SetCapacitiable(LinkedHashSet.newLinkedHashSet(size))) ); } @@ -364,9 +373,57 @@ public class WhiteBoxResizeTest { public void requestedSize(String label, // unused, included for diagnostics int size, // unused, included for diagnostics int expectedCapacity, - Supplier> s) { - Map map = s.get(); - map.put("", ""); - assertEquals(capacity(map), expectedCapacity); + Supplier s) { + Capacitiable capacitiable = s.get(); + capacitiable.init(); + assertEquals(capacitiable.capacity(), expectedCapacity); } + + interface Capacitiable { + + void init(); + + int capacity(); + + } + + class MapCapacitiable implements Capacitiable { + + private final Map content; + + public MapCapacitiable(Map content) { + this.content = content; + } + + @Override + public void init() { + content.put("", ""); + } + + @Override + public int capacity() { + return table(content).length; + } + } + + class SetCapacitiable implements Capacitiable { + + private final Set content; + + public SetCapacitiable(Set content) { + this.content = content; + } + + @Override + public void init() { + content.add(""); + } + + @Override + public int capacity() { + HashMap hashMap = (HashMap) HS_MAP.get(content); + return table(hashMap).length; + } + } + }