On Tue, 24 Sep 2024 19:40:23 GMT, David M. Lloyd <d...@openjdk.org> wrote:

>> Issue [JDK-8164908](https://bugs.openjdk.org/browse/JDK-8164908) added 
>> support for functionality required to continue to support IIOP and custom 
>> serializers in light of additional module-based restrictions on reflection. 
>> It was expected that these libraries would use `sun.misc.Unsafe` in order to 
>> access fields of serializable classes. However, with JEP 471, the methods 
>> necessary to do this are being removed.
>> 
>> To allow these libraries to continue to function, it is proposed to add two 
>> methods to `sun.reflect.ReflectionFactory` which will allow serialization 
>> libraries to acquire a method handle to generated `readObject`/`writeObject` 
>> methods which set or get the fields of the serializable class using the 
>> serialization `GetField`/`PutField` mechanism. These generated methods 
>> should be used by serialization libraries to serialize and deserialize 
>> classes which do not have a `readObject`/`writeObject` method or which use 
>> `ObjectInputStream.defaultReadObject`/`ObjectOutputStream.defaultWriteObject`
>>  to supplement default serialization.
>> 
>> It is also proposed to add methods which allow for the reading of 
>> serialization-specific private static final fields from classes which have 
>> them.
>> 
>> With the addition of these methods, serialization libraries no longer need 
>> to rely on `Unsafe` for serialization/deserialization activities.
>> cc: @AlanBateman
>
> David M. Lloyd has updated the pull request incrementally with one additional 
> commit since the last revision:
> 
>   Test fixes and finish renaming

The updated comments help explain better what's being implemented.

src/java.base/share/classes/java/io/ObjectStreamReflection.java line 75:

> 73:      * @param ois the object stream (must not be {@code null})
> 74:      * @throws IOException if the call to {@link 
> ObjectInputStream#readFields} or one of its field accessors throws this 
> exception type
> 75:      * @throws ClassNotFoundException if the call to {@link 
> ObjectInputStream#readFields} or one of its field accessors throws this 
> exception type

Please wrap lines longer than 100-120 chars.

src/java.base/share/classes/java/io/ObjectStreamReflection.java line 171:

> 169:             }
> 170:             return streamClass;
> 171:         }

Possibly move common setup into the helper function:

Suggestion:

        public MethodHandle defaultReadObject(Class<?> clazz) {
            return handleForClass(DRO_HANDLE, clazz, ObjectInputStream.class);
        }

        public MethodHandle defaultWriteObject(Class<?> clazz) {
            return handleForClass(DWO_HANDLE, clazz, ObjectOutputStream.class);
        }

        private static MethodHandle handleForClass(MethodHandle handle, final 
Class<?> clazz, Class<?> ioClass) {
            ObjectStreamClass streamClass = ObjectStreamClass.lookup(clazz);
            if (streamClass != null) {
                try {
                    streamClass.checkDefaultSerialize();
                    return handle.bindTo(streamClass)
                            .asType(MethodType.methodType(void.class, clazz, 
ioClass));
                } catch (InvalidClassException e) {
                    // ignore and return null
                }
            }
            return null;
        }

-------------

PR Review: https://git.openjdk.org/jdk/pull/19702#pullrequestreview-2322681630
PR Review Comment: https://git.openjdk.org/jdk/pull/19702#discussion_r1774053044
PR Review Comment: https://git.openjdk.org/jdk/pull/19702#discussion_r1774061651

Reply via email to