From 5185dbde67f07ff876305a9568bb5cebb7a7b384 Mon Sep 17 00:00:00 2001 From: Andrey Turbanov Date: Mon, 30 Aug 2021 13:12:42 +0000 Subject: [PATCH] 8273098: Unnecessary Vector usage in java.naming Reviewed-by: aefimov, dfuchs --- .../com/sun/jndi/ldap/LdapSchemaParser.java | 18 ++++++------ .../share/classes/com/sun/jndi/ldap/Obj.java | 29 +++++++++---------- .../com/sun/jndi/ldap/sasl/LdapSasl.java | 10 +++---- 3 files changed, 28 insertions(+), 29 deletions(-) diff --git a/src/java.naming/share/classes/com/sun/jndi/ldap/LdapSchemaParser.java b/src/java.naming/share/classes/com/sun/jndi/ldap/LdapSchemaParser.java index 3f7ff9b8bf1..7967c29fa83 100644 --- a/src/java.naming/share/classes/com/sun/jndi/ldap/LdapSchemaParser.java +++ b/src/java.naming/share/classes/com/sun/jndi/ldap/LdapSchemaParser.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -27,7 +27,7 @@ package com.sun.jndi.ldap; import javax.naming.*; import javax.naming.directory.*; -import java.util.Vector; +import java.util.ArrayList; /** * Netscape's 3.1 servers have some schema bugs: @@ -519,7 +519,7 @@ final class LdapSchemaParser { throws NamingException { int begin, end; - Vector values = new Vector<>(5); + ArrayList values = new ArrayList<>(5); if (debug) { System.err.println("ReadQDescrList: pos="+pos[0]); @@ -543,7 +543,7 @@ final class LdapSchemaParser { "' at begin=" + begin + " end =" + end); } - values.addElement(one[0]); + values.add(one[0]); skipWhitespace(string, pos); begin = pos[0]; } @@ -552,7 +552,7 @@ final class LdapSchemaParser { String[] answer = new String[values.size()]; for (int i = 0; i < answer.length; i++) { - answer[i] = values.elementAt(i); + answer[i] = values.get(i); } return answer; } @@ -613,7 +613,7 @@ final class LdapSchemaParser { int begin, cur, end; String oidName = null; - Vector values = new Vector<>(5); + ArrayList values = new ArrayList<>(5); if (debug) { System.err.println("ReadOIDList: pos="+pos[0]); @@ -641,7 +641,7 @@ final class LdapSchemaParser { System.err.println("ReadOIDList: found '" + oidName + "' at begin=" + begin + " end =" + end); } - values.addElement(oidName); + values.add(oidName); pos[0] = cur + 1; skipWhitespace(string, pos); begin = pos[0]; @@ -656,13 +656,13 @@ final class LdapSchemaParser { int wsBegin = findTrailingWhitespace(string, end - 1); oidName = string.substring(begin, wsBegin); - values.addElement(oidName); + values.add(oidName); pos[0] = end+1; String[] answer = new String[values.size()]; for (int i = 0; i < answer.length; i++) { - answer[i] = values.elementAt(i); + answer[i] = values.get(i); } return answer; } diff --git a/src/java.naming/share/classes/com/sun/jndi/ldap/Obj.java b/src/java.naming/share/classes/com/sun/jndi/ldap/Obj.java index 8ea0a5d7dee..da9e1926a5a 100644 --- a/src/java.naming/share/classes/com/sun/jndi/ldap/Obj.java +++ b/src/java.naming/share/classes/com/sun/jndi/ldap/Obj.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -38,9 +38,9 @@ import java.io.ObjectOutputStream; import java.io.ObjectStreamClass; import java.io.InputStream; +import java.util.ArrayList; import java.util.Base64; import java.util.Hashtable; -import java.util.Vector; import java.util.StringTokenizer; import java.lang.reflect.Proxy; @@ -205,13 +205,13 @@ final class Obj { } else { StringTokenizer parser = new StringTokenizer((String)codebaseAttr.get()); - Vector vec = new Vector<>(10); + ArrayList list = new ArrayList<>(10); while (parser.hasMoreTokens()) { - vec.addElement(parser.nextToken()); + list.add(parser.nextToken()); } - String[] answer = new String[vec.size()]; + String[] answer = new String[list.size()]; for (int i = 0; i < answer.length; i++) { - answer[i] = vec.elementAt(i); + answer[i] = list.get(i); } return answer; } @@ -409,11 +409,10 @@ final class Obj { ClassLoader cl = helper.getURLClassLoader(codebases); /* - * Temporary Vector for decoded RefAddr addresses - used to ensure + * Temporary array for decoded RefAddr addresses - used to ensure * unordered addresses are correctly re-ordered. */ - Vector refAddrList = new Vector<>(); - refAddrList.setSize(attr.size()); + RefAddr[] refAddrList = new RefAddr[attr.size()]; for (NamingEnumeration vals = attr.getAll(); vals.hasMore(); ) { @@ -464,7 +463,7 @@ final class Obj { // extract content if (start == val.length()) { // Empty content - refAddrList.setElementAt(new StringRefAddr(type, null), posn); + refAddrList[posn] = new StringRefAddr(type, null); } else if (val.charAt(start) == separator) { // Double separators indicate a non-StringRefAddr // Content is a Base64-encoded serialized RefAddr @@ -480,17 +479,17 @@ final class Obj { decoder.decode(val.substring(start).getBytes()), cl); - refAddrList.setElementAt(ra, posn); + refAddrList[posn] = ra; } else { // Single separator indicates a StringRefAddr - refAddrList.setElementAt(new StringRefAddr(type, - val.substring(start)), posn); + refAddrList[posn] = new StringRefAddr(type, + val.substring(start)); } } // Copy to real reference - for (int i = 0; i < refAddrList.size(); i++) { - ref.add(refAddrList.elementAt(i)); + for (int i = 0; i < refAddrList.length; i++) { + ref.add(refAddrList[i]); } } diff --git a/src/java.naming/share/classes/com/sun/jndi/ldap/sasl/LdapSasl.java b/src/java.naming/share/classes/com/sun/jndi/ldap/sasl/LdapSasl.java index 9a6145dc20c..bc557bfaa35 100644 --- a/src/java.naming/share/classes/com/sun/jndi/ldap/sasl/LdapSasl.java +++ b/src/java.naming/share/classes/com/sun/jndi/ldap/sasl/LdapSasl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -27,7 +27,7 @@ package com.sun.jndi.ldap.sasl; import java.io.*; import java.security.cert.X509Certificate; -import java.util.Vector; +import java.util.ArrayList; import java.util.Hashtable; import java.util.StringTokenizer; @@ -216,13 +216,13 @@ public final class LdapSasl { */ private static String[] getSaslMechanismNames(String str) { StringTokenizer parser = new StringTokenizer(str); - Vector mechs = new Vector<>(10); + ArrayList mechs = new ArrayList<>(10); while (parser.hasMoreTokens()) { - mechs.addElement(parser.nextToken()); + mechs.add(parser.nextToken()); } String[] mechNames = new String[mechs.size()]; for (int i = 0; i < mechs.size(); i++) { - mechNames[i] = mechs.elementAt(i); + mechNames[i] = mechs.get(i); } return mechNames; }