8284780: Need methods to create pre-sized HashSet and LinkedHashSet
Reviewed-by: naoto, bpb, dfuchs, ascarpino
This commit is contained in:
parent
a941bc2de6
commit
e01cd7c3ed
@ -56,7 +56,7 @@ abstract class PBEKeyFactory extends SecretKeyFactorySpi {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static {
|
static {
|
||||||
validTypes = new HashSet<>(17);
|
validTypes = HashSet.newHashSet(17);
|
||||||
validTypes.add("PBEWithMD5AndDES".toUpperCase(Locale.ENGLISH));
|
validTypes.add("PBEWithMD5AndDES".toUpperCase(Locale.ENGLISH));
|
||||||
validTypes.add("PBEWithSHA1AndDESede".toUpperCase(Locale.ENGLISH));
|
validTypes.add("PBEWithSHA1AndDESede".toUpperCase(Locale.ENGLISH));
|
||||||
validTypes.add("PBEWithSHA1AndRC2_40".toUpperCase(Locale.ENGLISH));
|
validTypes.add("PBEWithSHA1AndRC2_40".toUpperCase(Locale.ENGLISH));
|
||||||
|
@ -1648,7 +1648,7 @@ public final class ObjectStreamClass implements Serializable {
|
|||||||
|
|
||||||
ObjectStreamField[] boundFields =
|
ObjectStreamField[] boundFields =
|
||||||
new ObjectStreamField[serialPersistentFields.length];
|
new ObjectStreamField[serialPersistentFields.length];
|
||||||
Set<String> fieldNames = new HashSet<>(serialPersistentFields.length);
|
Set<String> fieldNames = HashSet.newHashSet(serialPersistentFields.length);
|
||||||
|
|
||||||
for (int i = 0; i < serialPersistentFields.length; i++) {
|
for (int i = 0; i < serialPersistentFields.length; i++) {
|
||||||
ObjectStreamField spf = serialPersistentFields[i];
|
ObjectStreamField spf = serialPersistentFields[i];
|
||||||
|
@ -310,7 +310,7 @@ import static jdk.internal.org.objectweb.asm.Opcodes.*;
|
|||||||
interfaceNames = new String[]{interfaceName};
|
interfaceNames = new String[]{interfaceName};
|
||||||
} else {
|
} else {
|
||||||
// Assure no duplicate interfaces (ClassFormatError)
|
// Assure no duplicate interfaces (ClassFormatError)
|
||||||
Set<String> itfs = new LinkedHashSet<>(altInterfaces.length + 1);
|
Set<String> itfs = LinkedHashSet.newLinkedHashSet(altInterfaces.length + 1);
|
||||||
itfs.add(interfaceName);
|
itfs.add(interfaceName);
|
||||||
for (Class<?> i : altInterfaces) {
|
for (Class<?> i : altInterfaces) {
|
||||||
itfs.add(i.getName().replace('.', '/'));
|
itfs.add(i.getName().replace('.', '/'));
|
||||||
|
@ -718,7 +718,7 @@ public abstract class Charset
|
|||||||
if (aliasSet != null)
|
if (aliasSet != null)
|
||||||
return aliasSet;
|
return aliasSet;
|
||||||
int n = aliases.length;
|
int n = aliases.length;
|
||||||
HashSet<String> hs = new HashSet<>(n);
|
HashSet<String> hs = HashSet.newHashSet(n);
|
||||||
for (int i = 0; i < n; i++)
|
for (int i = 0; i < n; i++)
|
||||||
hs.add(aliases[i]);
|
hs.add(aliases[i]);
|
||||||
aliasSet = Collections.unmodifiableSet(hs);
|
aliasSet = Collections.unmodifiableSet(hs);
|
||||||
|
@ -123,7 +123,7 @@ public final class DecimalStyle {
|
|||||||
*/
|
*/
|
||||||
public static Set<Locale> getAvailableLocales() {
|
public static Set<Locale> getAvailableLocales() {
|
||||||
Locale[] l = DecimalFormatSymbols.getAvailableLocales();
|
Locale[] l = DecimalFormatSymbols.getAvailableLocales();
|
||||||
Set<Locale> locales = new HashSet<>(l.length);
|
Set<Locale> locales = HashSet.newHashSet(l.length);
|
||||||
Collections.addAll(locales, l);
|
Collections.addAll(locales, l);
|
||||||
return locales;
|
return locales;
|
||||||
}
|
}
|
||||||
|
@ -2640,14 +2640,7 @@ public abstract class Calendar implements Serializable, Cloneable, Comparable<Ca
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static class AvailableCalendarTypes {
|
private static class AvailableCalendarTypes {
|
||||||
private static final Set<String> SET;
|
private static final Set<String> SET = Set.of("gregory", "buddhist", "japanese");
|
||||||
static {
|
|
||||||
Set<String> set = new HashSet<>(3);
|
|
||||||
set.add("gregory");
|
|
||||||
set.add("buddhist");
|
|
||||||
set.add("japanese");
|
|
||||||
SET = Collections.unmodifiableSet(set);
|
|
||||||
}
|
|
||||||
private AvailableCalendarTypes() {
|
private AvailableCalendarTypes() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -125,6 +125,10 @@ public class HashSet<E>
|
|||||||
* Constructs a new, empty set; the backing {@code HashMap} instance has
|
* Constructs a new, empty set; the backing {@code HashMap} instance has
|
||||||
* the specified initial capacity and the specified load factor.
|
* 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 initialCapacity the initial capacity of the hash map
|
||||||
* @param loadFactor the load factor of the hash map
|
* @param loadFactor the load factor of the hash map
|
||||||
* @throws IllegalArgumentException if the initial capacity is less
|
* @throws IllegalArgumentException if the initial capacity is less
|
||||||
@ -138,6 +142,10 @@ public class HashSet<E>
|
|||||||
* Constructs a new, empty set; the backing {@code HashMap} instance has
|
* Constructs a new, empty set; the backing {@code HashMap} instance has
|
||||||
* the specified initial capacity and default load factor (0.75).
|
* 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
|
* @param initialCapacity the initial capacity of the hash table
|
||||||
* @throws IllegalArgumentException if the initial capacity is less
|
* @throws IllegalArgumentException if the initial capacity is less
|
||||||
* than zero
|
* than zero
|
||||||
@ -372,4 +380,21 @@ public class HashSet<E>
|
|||||||
public <T> T[] toArray(T[] a) {
|
public <T> T[] toArray(T[] a) {
|
||||||
return map.keysToArray(map.prepareArray(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 <T> the type of elements maintained by the new set
|
||||||
|
* @return the newly created set
|
||||||
|
* @throws IllegalArgumentException if numElements is negative
|
||||||
|
* @since 19
|
||||||
|
*/
|
||||||
|
public static <T> HashSet<T> newHashSet(int numElements) {
|
||||||
|
return new HashSet<>(HashMap.calculateHashMapCapacity(numElements));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -126,6 +126,10 @@ public class LinkedHashSet<E>
|
|||||||
* Constructs a new, empty linked hash set with the specified initial
|
* Constructs a new, empty linked hash set with the specified initial
|
||||||
* capacity and load factor.
|
* 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 initialCapacity the initial capacity of the linked hash set
|
||||||
* @param loadFactor the load factor of the linked hash set
|
* @param loadFactor the load factor of the linked hash set
|
||||||
* @throws IllegalArgumentException if the initial capacity is less
|
* @throws IllegalArgumentException if the initial capacity is less
|
||||||
@ -139,6 +143,10 @@ public class LinkedHashSet<E>
|
|||||||
* Constructs a new, empty linked hash set with the specified initial
|
* Constructs a new, empty linked hash set with the specified initial
|
||||||
* capacity and the default load factor (0.75).
|
* 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
|
* @param initialCapacity the initial capacity of the LinkedHashSet
|
||||||
* @throws IllegalArgumentException if the initial capacity is less
|
* @throws IllegalArgumentException if the initial capacity is less
|
||||||
* than zero
|
* than zero
|
||||||
@ -166,7 +174,7 @@ public class LinkedHashSet<E>
|
|||||||
* @throws NullPointerException if the specified collection is null
|
* @throws NullPointerException if the specified collection is null
|
||||||
*/
|
*/
|
||||||
public LinkedHashSet(Collection<? extends E> c) {
|
public LinkedHashSet(Collection<? extends E> c) {
|
||||||
super(Math.max(2*c.size(), 11), .75f, true);
|
super(HashMap.calculateHashMapCapacity(Math.max(c.size(), 12)), .75f, true);
|
||||||
addAll(c);
|
addAll(c);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -193,4 +201,21 @@ public class LinkedHashSet<E>
|
|||||||
public Spliterator<E> spliterator() {
|
public Spliterator<E> spliterator() {
|
||||||
return Spliterators.spliterator(this, Spliterator.DISTINCT | Spliterator.ORDERED);
|
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 <T> the type of elements maintained by the new set
|
||||||
|
* @return the newly created set
|
||||||
|
* @throws IllegalArgumentException if numElements is negative
|
||||||
|
* @since 19
|
||||||
|
*/
|
||||||
|
public static <T> LinkedHashSet<T> newLinkedHashSet(int numElements) {
|
||||||
|
return new LinkedHashSet<>(HashMap.calculateHashMapCapacity(numElements));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -446,7 +446,7 @@ public final class ModuleInfo {
|
|||||||
|
|
||||||
int exports_to_count = in.readUnsignedShort();
|
int exports_to_count = in.readUnsignedShort();
|
||||||
if (exports_to_count > 0) {
|
if (exports_to_count > 0) {
|
||||||
Set<String> targets = new HashSet<>(exports_to_count);
|
Set<String> targets = HashSet.newHashSet(exports_to_count);
|
||||||
for (int j=0; j<exports_to_count; j++) {
|
for (int j=0; j<exports_to_count; j++) {
|
||||||
int exports_to_index = in.readUnsignedShort();
|
int exports_to_index = in.readUnsignedShort();
|
||||||
String target = cpool.getModuleName(exports_to_index);
|
String target = cpool.getModuleName(exports_to_index);
|
||||||
@ -486,7 +486,7 @@ public final class ModuleInfo {
|
|||||||
|
|
||||||
int open_to_count = in.readUnsignedShort();
|
int open_to_count = in.readUnsignedShort();
|
||||||
if (open_to_count > 0) {
|
if (open_to_count > 0) {
|
||||||
Set<String> targets = new HashSet<>(open_to_count);
|
Set<String> targets = HashSet.newHashSet(open_to_count);
|
||||||
for (int j=0; j<open_to_count; j++) {
|
for (int j=0; j<open_to_count; j++) {
|
||||||
int opens_to_index = in.readUnsignedShort();
|
int opens_to_index = in.readUnsignedShort();
|
||||||
String target = cpool.getModuleName(opens_to_index);
|
String target = cpool.getModuleName(opens_to_index);
|
||||||
@ -540,7 +540,7 @@ public final class ModuleInfo {
|
|||||||
throws IOException
|
throws IOException
|
||||||
{
|
{
|
||||||
int package_count = in.readUnsignedShort();
|
int package_count = in.readUnsignedShort();
|
||||||
Set<String> packages = new HashSet<>(package_count);
|
Set<String> packages = HashSet.newHashSet(package_count);
|
||||||
for (int i=0; i<package_count; i++) {
|
for (int i=0; i<package_count; i++) {
|
||||||
int index = in.readUnsignedShort();
|
int index = in.readUnsignedShort();
|
||||||
String pn = cpool.getPackageName(index);
|
String pn = cpool.getPackageName(index);
|
||||||
|
@ -278,7 +278,7 @@ public class HttpURLConnection extends java.net.HttpURLConnection {
|
|||||||
allowRestrictedHeaders = Boolean.parseBoolean(
|
allowRestrictedHeaders = Boolean.parseBoolean(
|
||||||
props.getProperty("sun.net.http.allowRestrictedHeaders"));
|
props.getProperty("sun.net.http.allowRestrictedHeaders"));
|
||||||
if (!allowRestrictedHeaders) {
|
if (!allowRestrictedHeaders) {
|
||||||
restrictedHeaderSet = new HashSet<>(restrictedHeaders.length);
|
restrictedHeaderSet = HashSet.newHashSet(restrictedHeaders.length);
|
||||||
for (int i=0; i < restrictedHeaders.length; i++) {
|
for (int i=0; i < restrictedHeaders.length; i++) {
|
||||||
restrictedHeaderSet.add(restrictedHeaders[i].toLowerCase());
|
restrictedHeaderSet.add(restrictedHeaders[i].toLowerCase());
|
||||||
}
|
}
|
||||||
|
@ -230,7 +230,7 @@ abstract class AsynchronousServerSocketChannelImpl
|
|||||||
static final Set<SocketOption<?>> defaultOptions = defaultOptions();
|
static final Set<SocketOption<?>> defaultOptions = defaultOptions();
|
||||||
|
|
||||||
private static Set<SocketOption<?>> defaultOptions() {
|
private static Set<SocketOption<?>> defaultOptions() {
|
||||||
HashSet<SocketOption<?>> set = new HashSet<>(2);
|
HashSet<SocketOption<?>> set = HashSet.newHashSet(2);
|
||||||
set.add(StandardSocketOptions.SO_RCVBUF);
|
set.add(StandardSocketOptions.SO_RCVBUF);
|
||||||
set.add(StandardSocketOptions.SO_REUSEADDR);
|
set.add(StandardSocketOptions.SO_REUSEADDR);
|
||||||
if (Net.isReusePortAvailable()) {
|
if (Net.isReusePortAvailable()) {
|
||||||
|
@ -503,7 +503,7 @@ abstract class AsynchronousSocketChannelImpl
|
|||||||
static final Set<SocketOption<?>> defaultOptions = defaultOptions();
|
static final Set<SocketOption<?>> defaultOptions = defaultOptions();
|
||||||
|
|
||||||
private static Set<SocketOption<?>> defaultOptions() {
|
private static Set<SocketOption<?>> defaultOptions() {
|
||||||
HashSet<SocketOption<?>> set = new HashSet<>(5);
|
HashSet<SocketOption<?>> set = HashSet.newHashSet(5);
|
||||||
set.add(StandardSocketOptions.SO_SNDBUF);
|
set.add(StandardSocketOptions.SO_SNDBUF);
|
||||||
set.add(StandardSocketOptions.SO_RCVBUF);
|
set.add(StandardSocketOptions.SO_RCVBUF);
|
||||||
set.add(StandardSocketOptions.SO_KEEPALIVE);
|
set.add(StandardSocketOptions.SO_KEEPALIVE);
|
||||||
|
@ -105,7 +105,7 @@ abstract class AbstractPoller implements Runnable {
|
|||||||
// validate arguments before request to poller
|
// validate arguments before request to poller
|
||||||
if (dir == null)
|
if (dir == null)
|
||||||
throw new NullPointerException();
|
throw new NullPointerException();
|
||||||
Set<WatchEvent.Kind<?>> eventSet = new HashSet<>(events.length);
|
Set<WatchEvent.Kind<?>> eventSet = HashSet.newHashSet(events.length);
|
||||||
for (WatchEvent.Kind<?> event: events) {
|
for (WatchEvent.Kind<?> event: events) {
|
||||||
// standard events
|
// standard events
|
||||||
if (event == StandardWatchEventKinds.ENTRY_CREATE ||
|
if (event == StandardWatchEventKinds.ENTRY_CREATE ||
|
||||||
|
@ -95,7 +95,7 @@ class PollingWatchService
|
|||||||
throws IOException
|
throws IOException
|
||||||
{
|
{
|
||||||
// check events - CCE will be thrown if there are invalid elements
|
// check events - CCE will be thrown if there are invalid elements
|
||||||
final Set<WatchEvent.Kind<?>> eventSet = new HashSet<>(events.length);
|
final Set<WatchEvent.Kind<?>> eventSet = HashSet.newHashSet(events.length);
|
||||||
for (WatchEvent.Kind<?> event: events) {
|
for (WatchEvent.Kind<?> event: events) {
|
||||||
// standard events
|
// standard events
|
||||||
if (event == StandardWatchEventKinds.ENTRY_CREATE ||
|
if (event == StandardWatchEventKinds.ENTRY_CREATE ||
|
||||||
|
@ -514,7 +514,7 @@ public class PKCS7 {
|
|||||||
// CRLs (optional)
|
// CRLs (optional)
|
||||||
if (crls != null && crls.length != 0) {
|
if (crls != null && crls.length != 0) {
|
||||||
// cast to X509CRLImpl[] since X509CRLImpl implements DerEncoder
|
// cast to X509CRLImpl[] since X509CRLImpl implements DerEncoder
|
||||||
Set<X509CRLImpl> implCRLs = new HashSet<>(crls.length);
|
Set<X509CRLImpl> implCRLs = HashSet.newHashSet(crls.length);
|
||||||
for (X509CRL crl: crls) {
|
for (X509CRL crl: crls) {
|
||||||
if (crl instanceof X509CRLImpl)
|
if (crl instanceof X509CRLImpl)
|
||||||
implCRLs.add((X509CRLImpl) crl);
|
implCRLs.add((X509CRLImpl) crl);
|
||||||
|
@ -92,7 +92,7 @@ class ConstraintsChecker extends PKIXCertPathChecker {
|
|||||||
@Override
|
@Override
|
||||||
public Set<String> getSupportedExtensions() {
|
public Set<String> getSupportedExtensions() {
|
||||||
if (supportedExts == null) {
|
if (supportedExts == null) {
|
||||||
supportedExts = new HashSet<String>(2);
|
supportedExts = HashSet.newHashSet(2);
|
||||||
supportedExts.add(BasicConstraints_Id.toString());
|
supportedExts.add(BasicConstraints_Id.toString());
|
||||||
supportedExts.add(NameConstraints_Id.toString());
|
supportedExts.add(NameConstraints_Id.toString());
|
||||||
supportedExts = Collections.unmodifiableSet(supportedExts);
|
supportedExts = Collections.unmodifiableSet(supportedExts);
|
||||||
|
@ -81,8 +81,8 @@ final class ForwardBuilder extends Builder {
|
|||||||
|
|
||||||
// populate sets of trusted certificates and subject DNs
|
// populate sets of trusted certificates and subject DNs
|
||||||
trustAnchors = buildParams.trustAnchors();
|
trustAnchors = buildParams.trustAnchors();
|
||||||
trustedCerts = new HashSet<X509Certificate>(trustAnchors.size());
|
trustedCerts = HashSet.newHashSet(trustAnchors.size());
|
||||||
trustedSubjectDNs = new HashSet<X500Principal>(trustAnchors.size());
|
trustedSubjectDNs = HashSet.newHashSet(trustAnchors.size());
|
||||||
for (TrustAnchor anchor : trustAnchors) {
|
for (TrustAnchor anchor : trustAnchors) {
|
||||||
X509Certificate trustedCert = anchor.getTrustedCert();
|
X509Certificate trustedCert = anchor.getTrustedCert();
|
||||||
if (trustedCert != null) {
|
if (trustedCert != null) {
|
||||||
|
@ -85,7 +85,7 @@ class KeyChecker extends PKIXCertPathChecker {
|
|||||||
@Override
|
@Override
|
||||||
public Set<String> getSupportedExtensions() {
|
public Set<String> getSupportedExtensions() {
|
||||||
if (supportedExts == null) {
|
if (supportedExts == null) {
|
||||||
supportedExts = new HashSet<String>(3);
|
supportedExts = HashSet.newHashSet(3);
|
||||||
supportedExts.add(KeyUsage_Id.toString());
|
supportedExts.add(KeyUsage_Id.toString());
|
||||||
supportedExts.add(ExtendedKeyUsage_Id.toString());
|
supportedExts.add(ExtendedKeyUsage_Id.toString());
|
||||||
supportedExts.add(SubjectAlternativeName_Id.toString());
|
supportedExts.add(SubjectAlternativeName_Id.toString());
|
||||||
|
@ -93,7 +93,7 @@ class PolicyChecker extends PKIXCertPathChecker {
|
|||||||
if (initialPolicies.isEmpty()) {
|
if (initialPolicies.isEmpty()) {
|
||||||
// if no initialPolicies are specified by user, set
|
// if no initialPolicies are specified by user, set
|
||||||
// initPolicies to be anyPolicy by default
|
// initPolicies to be anyPolicy by default
|
||||||
this.initPolicies = new HashSet<String>(1);
|
this.initPolicies = HashSet.newHashSet(1);
|
||||||
this.initPolicies.add(ANY_POLICY);
|
this.initPolicies.add(ANY_POLICY);
|
||||||
} else {
|
} else {
|
||||||
this.initPolicies = new HashSet<String>(initialPolicies);
|
this.initPolicies = new HashSet<String>(initialPolicies);
|
||||||
@ -154,7 +154,7 @@ class PolicyChecker extends PKIXCertPathChecker {
|
|||||||
@Override
|
@Override
|
||||||
public Set<String> getSupportedExtensions() {
|
public Set<String> getSupportedExtensions() {
|
||||||
if (supportedExts == null) {
|
if (supportedExts == null) {
|
||||||
supportedExts = new HashSet<String>(4);
|
supportedExts = HashSet.newHashSet(4);
|
||||||
supportedExts.add(CertificatePolicies_Id.toString());
|
supportedExts.add(CertificatePolicies_Id.toString());
|
||||||
supportedExts.add(PolicyMappings_Id.toString());
|
supportedExts.add(PolicyMappings_Id.toString());
|
||||||
supportedExts.add(PolicyConstraints_Id.toString());
|
supportedExts.add(PolicyConstraints_Id.toString());
|
||||||
|
@ -573,7 +573,7 @@ final class CertificateMessage {
|
|||||||
if ((subAltDnsName != null) && !subAltDnsName.isEmpty()) {
|
if ((subAltDnsName != null) && !subAltDnsName.isEmpty()) {
|
||||||
if (subAltDnsNames == null) {
|
if (subAltDnsNames == null) {
|
||||||
subAltDnsNames =
|
subAltDnsNames =
|
||||||
new HashSet<>(subjectAltNames.size());
|
HashSet.newHashSet(subjectAltNames.size());
|
||||||
}
|
}
|
||||||
subAltDnsNames.add(subAltDnsName);
|
subAltDnsNames.add(subAltDnsName);
|
||||||
}
|
}
|
||||||
|
@ -110,7 +110,7 @@ final class SunX509KeyManagerImpl extends X509ExtendedKeyManager {
|
|||||||
// assert privateKey and certificates != null
|
// assert privateKey and certificates != null
|
||||||
this.privateKey = privateKey;
|
this.privateKey = privateKey;
|
||||||
this.certificates = certificates;
|
this.certificates = certificates;
|
||||||
this.issuerX500Principals = new HashSet<>(certificates.length);
|
this.issuerX500Principals = HashSet.newHashSet(certificates.length);
|
||||||
for (X509Certificate certificate : certificates) {
|
for (X509Certificate certificate : certificates) {
|
||||||
issuerX500Principals.add(certificate.getIssuerX500Principal());
|
issuerX500Principals.add(certificate.getIssuerX500Principal());
|
||||||
}
|
}
|
||||||
|
@ -313,7 +313,7 @@ public final class InternalLocaleBuilder {
|
|||||||
clearExtensions();
|
clearExtensions();
|
||||||
|
|
||||||
if (!LocaleUtils.isEmpty(bcpExtensions)) {
|
if (!LocaleUtils.isEmpty(bcpExtensions)) {
|
||||||
Set<CaseInsensitiveChar> done = new HashSet<>(bcpExtensions.size());
|
Set<CaseInsensitiveChar> done = HashSet.newHashSet(bcpExtensions.size());
|
||||||
for (String bcpExt : bcpExtensions) {
|
for (String bcpExt : bcpExtensions) {
|
||||||
CaseInsensitiveChar key = new CaseInsensitiveChar(bcpExt);
|
CaseInsensitiveChar key = new CaseInsensitiveChar(bcpExt);
|
||||||
// ignore duplicates
|
// ignore duplicates
|
||||||
|
@ -148,7 +148,7 @@ public class OpeningHandshake {
|
|||||||
private static Collection<String> createRequestSubprotocols(
|
private static Collection<String> createRequestSubprotocols(
|
||||||
Collection<String> subprotocols)
|
Collection<String> subprotocols)
|
||||||
{
|
{
|
||||||
LinkedHashSet<String> sp = new LinkedHashSet<>(subprotocols.size(), 1);
|
LinkedHashSet<String> sp = LinkedHashSet.newLinkedHashSet(subprotocols.size());
|
||||||
for (String s : subprotocols) {
|
for (String s : subprotocols) {
|
||||||
if (s.trim().isEmpty() || !isValidName(s)) {
|
if (s.trim().isEmpty() || !isValidName(s)) {
|
||||||
throw illegal("Bad subprotocol syntax: " + s);
|
throw illegal("Bad subprotocol syntax: " + s);
|
||||||
|
@ -384,7 +384,7 @@ public class TCPEndpoint implements Endpoint {
|
|||||||
Set<TCPTransport> s;
|
Set<TCPTransport> s;
|
||||||
synchronized (localEndpoints) {
|
synchronized (localEndpoints) {
|
||||||
// presize s to number of localEndpoints
|
// presize s to number of localEndpoints
|
||||||
s = new HashSet<TCPTransport>(localEndpoints.size());
|
s = HashSet.newHashSet(localEndpoints.size());
|
||||||
for (LinkedList<TCPEndpoint> epList : localEndpoints.values()) {
|
for (LinkedList<TCPEndpoint> epList : localEndpoints.values()) {
|
||||||
/*
|
/*
|
||||||
* Each local endpoint has its transport added to s.
|
* Each local endpoint has its transport added to s.
|
||||||
|
@ -3309,7 +3309,7 @@ class ZipFileSystem extends FileSystem {
|
|||||||
public Optional<Set<PosixFilePermission>> storedPermissions() {
|
public Optional<Set<PosixFilePermission>> storedPermissions() {
|
||||||
Set<PosixFilePermission> perms = null;
|
Set<PosixFilePermission> perms = null;
|
||||||
if (posixPerms != -1) {
|
if (posixPerms != -1) {
|
||||||
perms = new HashSet<>(PosixFilePermission.values().length);
|
perms = HashSet.newHashSet(PosixFilePermission.values().length);
|
||||||
for (PosixFilePermission perm : PosixFilePermission.values()) {
|
for (PosixFilePermission perm : PosixFilePermission.values()) {
|
||||||
if ((posixPerms & ZipUtils.permToFlag(perm)) != 0) {
|
if ((posixPerms & ZipUtils.permToFlag(perm)) != 0) {
|
||||||
perms.add(perm);
|
perms.add(perm);
|
||||||
|
@ -81,7 +81,7 @@ public class UnreferencedRAFClosesFd {
|
|||||||
|
|
||||||
// Prepare to wait for FOS, FD, Cleanup to be reclaimed
|
// Prepare to wait for FOS, FD, Cleanup to be reclaimed
|
||||||
ReferenceQueue<Object> queue = new ReferenceQueue<>();
|
ReferenceQueue<Object> queue = new ReferenceQueue<>();
|
||||||
HashSet<Reference<?>> pending = new HashSet<>(3);
|
HashSet<Reference<?>> pending = HashSet.newHashSet(3);
|
||||||
pending.add(new WeakReference<>(cleanup, queue));
|
pending.add(new WeakReference<>(cleanup, queue));
|
||||||
pending.add(new WeakReference<>(raf, queue));
|
pending.add(new WeakReference<>(raf, queue));
|
||||||
pending.add(new WeakReference<>(fd, queue));
|
pending.add(new WeakReference<>(fd, queue));
|
||||||
|
@ -57,7 +57,7 @@ public class TestFileEncoding {
|
|||||||
private String expectedEncoding; // Expected value for file.encoding
|
private String expectedEncoding; // Expected value for file.encoding
|
||||||
private String langVar = null; // Value to set for LANG, etc
|
private String langVar = null; // Value to set for LANG, etc
|
||||||
|
|
||||||
private static Set<String> envToRm = new HashSet<>(3);
|
private static Set<String> envToRm = HashSet.newHashSet(3);
|
||||||
static {
|
static {
|
||||||
// Take these vars out of the test's run environment, possibly adding
|
// Take these vars out of the test's run environment, possibly adding
|
||||||
// our own value back in.
|
// our own value back in.
|
||||||
|
@ -434,7 +434,7 @@ public class FormatIteratorTest extends IntlTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Set<Attribute> makeAttributes(List<Object> names) {
|
public Set<Attribute> makeAttributes(List<Object> names) {
|
||||||
Set<Attribute> set = new HashSet<>(Math.max(1, names.size()));
|
Set<Attribute> set = HashSet.newHashSet(names.size());
|
||||||
|
|
||||||
for (int counter = 0; counter < names.size(); counter++) {
|
for (int counter = 0; counter < names.size(); counter++) {
|
||||||
set.add(makeAttribute((String)names.get(counter)));
|
set.add(makeAttribute((String)names.get(counter)));
|
||||||
|
@ -29,13 +29,16 @@ import java.lang.invoke.MethodHandle;
|
|||||||
import java.lang.invoke.MethodHandles;
|
import java.lang.invoke.MethodHandles;
|
||||||
import java.lang.invoke.MethodType;
|
import java.lang.invoke.MethodType;
|
||||||
import java.lang.invoke.VarHandle;
|
import java.lang.invoke.VarHandle;
|
||||||
|
import java.lang.reflect.Field;
|
||||||
import java.util.AbstractMap;
|
import java.util.AbstractMap;
|
||||||
import java.util.AbstractSet;
|
import java.util.AbstractSet;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.LinkedHashMap;
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.LinkedHashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
@ -48,7 +51,7 @@ import static org.testng.Assert.assertNull;
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* @test
|
* @test
|
||||||
* @bug 8186958 8210280 8281631 8285386
|
* @bug 8186958 8210280 8281631 8285386 8284780
|
||||||
* @modules java.base/java.util:open
|
* @modules java.base/java.util:open
|
||||||
* @summary White box tests for HashMap-related internals around table sizing
|
* @summary White box tests for HashMap-related internals around table sizing
|
||||||
* @run testng/othervm -Xmx2g WhiteBoxResizeTest
|
* @run testng/othervm -Xmx2g WhiteBoxResizeTest
|
||||||
@ -58,6 +61,7 @@ public class WhiteBoxResizeTest {
|
|||||||
final MethodHandle TABLE_SIZE_FOR;
|
final MethodHandle TABLE_SIZE_FOR;
|
||||||
final VarHandle HM_TABLE;
|
final VarHandle HM_TABLE;
|
||||||
final VarHandle WHM_TABLE;
|
final VarHandle WHM_TABLE;
|
||||||
|
final VarHandle HS_MAP;
|
||||||
|
|
||||||
public WhiteBoxResizeTest() throws ReflectiveOperationException {
|
public WhiteBoxResizeTest() throws ReflectiveOperationException {
|
||||||
MethodHandles.Lookup hmlookup = MethodHandles.privateLookupIn(HashMap.class, MethodHandles.lookup());
|
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());
|
MethodHandles.Lookup whmlookup = MethodHandles.privateLookupIn(WeakHashMap.class, MethodHandles.lookup());
|
||||||
WHM_TABLE = whmlookup.unreflectVarHandle(WeakHashMap.class.getDeclaredField("table"));
|
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,
|
Object[] rsc(String label,
|
||||||
int size,
|
int size,
|
||||||
int expectedCapacity,
|
int expectedCapacity,
|
||||||
Supplier<Map<String, String>> supplier) {
|
Supplier<Capacitiable> supplier) {
|
||||||
return new Object[]{label, size, expectedCapacity, supplier};
|
return new Object[]{label, size, expectedCapacity, supplier};
|
||||||
}
|
}
|
||||||
|
|
||||||
List<Object[]> genRequestedSizeCases(int size, int cap) {
|
List<Object[]> genRequestedSizeCases(int size, int cap) {
|
||||||
return Arrays.asList(
|
return Arrays.asList(
|
||||||
rsc("rshm", size, cap, () -> HashMap.newHashMap(size)),
|
rsc("rshm", size, cap, () -> new MapCapacitiable(HashMap.newHashMap(size))),
|
||||||
rsc("rslm", size, cap, () -> LinkedHashMap.newLinkedHashMap(size)),
|
rsc("rslm", size, cap, () -> new MapCapacitiable(LinkedHashMap.newLinkedHashMap(size))),
|
||||||
rsc("rswm", size, cap, () -> WeakHashMap.newWeakHashMap(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
|
public void requestedSize(String label, // unused, included for diagnostics
|
||||||
int size, // unused, included for diagnostics
|
int size, // unused, included for diagnostics
|
||||||
int expectedCapacity,
|
int expectedCapacity,
|
||||||
Supplier<Map<String, String>> s) {
|
Supplier<Capacitiable> s) {
|
||||||
Map<String, String> map = s.get();
|
Capacitiable capacitiable = s.get();
|
||||||
map.put("", "");
|
capacitiable.init();
|
||||||
assertEquals(capacity(map), expectedCapacity);
|
assertEquals(capacitiable.capacity(), expectedCapacity);
|
||||||
|
}
|
||||||
|
|
||||||
|
interface Capacitiable {
|
||||||
|
|
||||||
|
void init();
|
||||||
|
|
||||||
|
int capacity();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class MapCapacitiable implements Capacitiable {
|
||||||
|
|
||||||
|
private final Map<String, String> content;
|
||||||
|
|
||||||
|
public MapCapacitiable(Map<String, String> 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<String> content;
|
||||||
|
|
||||||
|
public SetCapacitiable(Set<String> 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;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user