From cc0ed401ec982565a2b865bd86fb67a0dbef62df Mon Sep 17 00:00:00 2001 From: Stuart Marks Date: Fri, 20 Nov 2020 18:26:38 +0000 Subject: [PATCH] 8037384: Fix wording in Javadoc of java.io.Serializable 8231547: Serializable class doc should link to serialization specification Reviewed-by: rriggs, iris, chegar --- .../classes/java/io/ObjectInputStream.java | 5 +-- .../classes/java/io/ObjectOutputStream.java | 2 +- .../classes/java/io/ObjectStreamClass.java | 4 +-- .../share/classes/java/io/Serializable.java | 35 ++++++++++--------- .../share/classes/java/io/package-info.java | 2 +- 5 files changed, 26 insertions(+), 22 deletions(-) diff --git a/src/java.base/share/classes/java/io/ObjectInputStream.java b/src/java.base/share/classes/java/io/ObjectInputStream.java index 354d8f8d2f1..f0b0db20f8c 100644 --- a/src/java.base/share/classes/java/io/ObjectInputStream.java +++ b/src/java.base/share/classes/java/io/ObjectInputStream.java @@ -242,7 +242,8 @@ import sun.security.action.GetIntegerAction; * The record components are deserialized prior to the invocation of the record * constructor, hence this limitation (see * - * [Section 1.14, "Circular References" for additional information). + * Java Object Serialization Specification, + * Section 1.14, "Circular References" for additional information). * The process by which record objects are serialized or externalized cannot be * customized; any class-specific writeObject, readObject, readObjectNoData, * writeExternal, and readExternal methods defined by record classes are @@ -262,7 +263,7 @@ import sun.security.action.GetIntegerAction; * @see java.io.ObjectOutputStream * @see java.io.Serializable * @see - * Object Serialization Specification, Section 3, Object Input Classes + * Java Object Serialization Specification, Section 3, "Object Input Classes" * @since 1.1 */ public class ObjectInputStream diff --git a/src/java.base/share/classes/java/io/ObjectOutputStream.java b/src/java.base/share/classes/java/io/ObjectOutputStream.java index 2ad8e698ab2..2bc0fc31f36 100644 --- a/src/java.base/share/classes/java/io/ObjectOutputStream.java +++ b/src/java.base/share/classes/java/io/ObjectOutputStream.java @@ -161,7 +161,7 @@ import sun.reflect.misc.ReflectUtil; * @see java.io.Serializable * @see java.io.Externalizable * @see - * Object Serialization Specification, Section 2, Object Output Classes + * Java Object Serialization Specification, Section 2, "Object Output Classes" * @since 1.1 */ public class ObjectOutputStream diff --git a/src/java.base/share/classes/java/io/ObjectStreamClass.java b/src/java.base/share/classes/java/io/ObjectStreamClass.java index 259a058842f..89d9c739aa7 100644 --- a/src/java.base/share/classes/java/io/ObjectStreamClass.java +++ b/src/java.base/share/classes/java/io/ObjectStreamClass.java @@ -76,13 +76,13 @@ import static java.io.ObjectStreamField.*; * *

The algorithm to compute the SerialVersionUID is described in * - * Object Serialization Specification, Section 4.6, Stream Unique Identifiers. + * Java Object Serialization Specification, Section 4.6, "Stream Unique Identifiers". * * @author Mike Warres * @author Roger Riggs * @see ObjectStreamField * @see - * Object Serialization Specification, Section 4, Class Descriptors + * Java Object Serialization Specification, Section 4, "Class Descriptors" * @since 1.1 */ public class ObjectStreamClass implements Serializable { diff --git a/src/java.base/share/classes/java/io/Serializable.java b/src/java.base/share/classes/java/io/Serializable.java index 4686d062108..deab67a710e 100644 --- a/src/java.base/share/classes/java/io/Serializable.java +++ b/src/java.base/share/classes/java/io/Serializable.java @@ -43,20 +43,19 @@ package java.io; * serializable. The serialization interface has no methods or fields * and serves only to identify the semantics of being serializable.

* - * To allow subtypes of non-serializable classes to be serialized, the - * subtype may assume responsibility for saving and restoring the - * state of the supertype's public, protected, and (if accessible) - * package fields. The subtype may assume this responsibility only if - * the class it extends has an accessible no-arg constructor to - * initialize the class's state. It is an error to declare a class - * Serializable if this is not the case. The error will be detected at - * runtime.

- * - * During deserialization, the fields of non-serializable classes will - * be initialized using the public or protected no-arg constructor of - * the class. A no-arg constructor must be accessible to the subclass - * that is serializable. The fields of serializable subclasses will - * be restored from the stream.

+ * It is possible for subtypes of non-serializable classes to be serialized + * and deserialized. During serialization, no data will be written for the + * fields of non-serializable superclasses. During deserialization, the fields of non-serializable + * superclasses will be initialized using the no-arg constructor of the first (bottommost) + * non-serializable superclass. This constructor must be accessible to the subclass that is being + * deserialized. It is an error to declare a class Serializable if this is not + * the case; the error will be detected at runtime. A serializable subtype may + * assume responsibility for saving and restoring the state of a non-serializable + * supertype's public, protected, and (if accessible) package-access fields. See + * the + * Java Object Serialization Specification, section 3.1, for + * a detailed specification of the deserialization process, including handling of + * serializable and non-serializable classes.

* * When traversing a graph, an object may be encountered that does not * support the Serializable interface. In this case the @@ -135,7 +134,8 @@ package java.io; * accessibility rules as writeReplace.

* * Enum types are all serializable and receive treatment defined by - * the Java Object Serialization Specification during + * the + * Java Object Serialization Specification during * serialization and deserialization. Any declarations of the special * handling methods discussed above are ignored for enum types.

* @@ -157,7 +157,8 @@ package java.io; * If a serializable class does not explicitly declare a serialVersionUID, then * the serialization runtime will calculate a default serialVersionUID value * for that class based on various aspects of the class, as described in the - * Java Object Serialization Specification. This specification defines the + * Java Object Serialization + * Specification. This specification defines the * serialVersionUID of an enum type to be 0L. However, it is strongly * recommended that all serializable classes other than enum types explicitly declare * serialVersionUID values, since the default serialVersionUID computation is @@ -179,6 +180,8 @@ package java.io; * @see java.io.ObjectOutput * @see java.io.ObjectInput * @see java.io.Externalizable + * @see + * Java Object Serialization Specification * @since 1.1 */ public interface Serializable { diff --git a/src/java.base/share/classes/java/io/package-info.java b/src/java.base/share/classes/java/io/package-info.java index 61c5babf016..1c41f9835e6 100644 --- a/src/java.base/share/classes/java/io/package-info.java +++ b/src/java.base/share/classes/java/io/package-info.java @@ -39,7 +39,7 @@ *

*