From 3e667cc40521dfb6d07dda07c2f33e37086ee64b Mon Sep 17 00:00:00 2001 From: "Tagir F. Valeev" Date: Sat, 1 May 2021 07:30:55 +0000 Subject: [PATCH] 8265356: need code example for getting canonical constructor of a Record Reviewed-by: smarks --- .../share/classes/java/lang/Class.java | 27 ++++++++++++++----- .../share/classes/java/lang/Record.java | 4 +++ 2 files changed, 24 insertions(+), 7 deletions(-) diff --git a/src/java.base/share/classes/java/lang/Class.java b/src/java.base/share/classes/java/lang/Class.java index aed28c2cc38..1463d905526 100644 --- a/src/java.base/share/classes/java/lang/Class.java +++ b/src/java.base/share/classes/java/lang/Class.java @@ -1631,7 +1631,7 @@ public final class Class implements java.io.Serializable, * in source code, can have a non-empty name including special * characters, such as "{@code $}". * - *

The simple name of an {@linkplain isArray() array class} is the simple name of the + *

The simple name of an {@linkplain #isArray() array class} is the simple name of the * component type with "[]" appended. In particular the simple * name of an array class whose component type is anonymous is "[]". * @@ -2361,6 +2361,19 @@ public final class Class implements java.io.Serializable, * Conversely, if {@link #isRecord()} returns {@code true}, then this method * returns a non-null value. * + * @apiNote + *

The following method can be used to find the record canonical constructor: + * + *

{@code
+     * static  Constructor getCanonicalConstructor(Class cls)
+     *     throws NoSuchMethodException {
+     *   Class[] paramTypes =
+     *     Arrays.stream(cls.getRecordComponents())
+     *           .map(RecordComponent::getType)
+     *           .toArray(Class[]::new);
+     *   return cls.getDeclaredConstructor(paramTypes);
+     * }}
+ * * @return An array of {@code RecordComponent} objects representing all the * record components of this record class, or {@code null} if this * class is not a record class @@ -3113,15 +3126,15 @@ public final class Class implements java.io.Serializable, return unsafe.compareAndSetReference(clazz, reflectionDataOffset, oldData, newData); } - static boolean casAnnotationType(Class clazz, - AnnotationType oldType, - AnnotationType newType) { + static boolean casAnnotationType(Class clazz, + AnnotationType oldType, + AnnotationType newType) { return unsafe.compareAndSetReference(clazz, annotationTypeOffset, oldType, newType); } - static boolean casAnnotationData(Class clazz, - AnnotationData oldData, - AnnotationData newData) { + static boolean casAnnotationData(Class clazz, + AnnotationData oldData, + AnnotationData newData) { return unsafe.compareAndSetReference(clazz, annotationDataOffset, oldData, newData); } } diff --git a/src/java.base/share/classes/java/lang/Record.java b/src/java.base/share/classes/java/lang/Record.java index 7441ec2faa5..2f8bd60ac5b 100644 --- a/src/java.base/share/classes/java/lang/Record.java +++ b/src/java.base/share/classes/java/lang/Record.java @@ -79,6 +79,10 @@ package java.lang; * Java Object Serialization Specification, Section 1.13, * "Serialization of Records". * + * @apiNote + * A record class structure can be obtained at runtime via reflection. + * See {@link Class#isRecord()} and {@link Class#getRecordComponents()} for more details. + * * @jls 8.10 Record Types * @since 16 */