6361826: (reflect) provide method for mapping strings to class object for primitive types

Reviewed-by: rriggs, mchung
This commit is contained in:
Joe Darcy 2023-07-14 20:18:23 +00:00
parent c84866ac0d
commit 19691fab48
3 changed files with 142 additions and 16 deletions

View file

@ -261,21 +261,6 @@ public class ObjectInputStream
/** marker for unshared objects in internal handle table */
private static final Object unsharedMarker = new Object();
/**
* immutable table mapping primitive type names to corresponding
* class objects
*/
private static final Map<String, Class<?>> primClasses =
Map.of("boolean", boolean.class,
"byte", byte.class,
"char", char.class,
"short", short.class,
"int", int.class,
"long", long.class,
"float", float.class,
"double", double.class,
"void", void.class);
private static class Caches {
/** cache of subclass security audit results */
static final ClassValue<Boolean> subclassAudits =
@ -803,7 +788,7 @@ public class ObjectInputStream
try {
return Class.forName(name, false, latestUserDefinedLoader());
} catch (ClassNotFoundException ex) {
Class<?> cl = primClasses.get(name);
Class<?> cl = Class.forPrimitiveName(name);
if (cl != null) {
return cl;
} else {

View file

@ -438,6 +438,9 @@ public final class Class<T> implements java.io.Serializable,
* If {@code name} denotes a primitive type or void, for example {@code I},
* an attempt will be made to locate a user-defined class in the unnamed package
* whose name is {@code I} instead.
* To obtain a {@code Class} object for a named primitive type
* such as {@code int} or {@code long} use {@link
* #forPrimitiveName(String)}.
*
* <p> To obtain the {@code Class} object associated with an array class,
* the name consists of one or more {@code '['} representing the depth
@ -628,6 +631,41 @@ public final class Class<T> implements java.io.Serializable,
}
}
/**
* {@return the {@code Class} object associated with the
* {@linkplain #isPrimitive() primitive type} of the given name}
* If the argument is not the name of a primitive type, {@code
* null} is returned.
*
* @param primitiveName the name of the primitive type to find
*
* @throws NullPointerException if the argument is {@code null}
*
* @jls 4.2 Primitive Types and Values
* @jls 15.8.2 Class Literals
* @since 22
*/
public static Class<?> forPrimitiveName(String primitiveName) {
return switch(primitiveName) {
// Integral types
case "int" -> int.class;
case "long" -> long.class;
case "short" -> short.class;
case "char" -> char.class;
case "byte" -> byte.class;
// Floating-point types
case "float" -> float.class;
case "double" -> double.class;
// Other types
case "boolean" -> boolean.class;
case "void" -> void.class;
default -> null;
};
}
/**
* Creates a new instance of the class represented by this {@code Class}
* object. The class is instantiated as if by a {@code new}