Stay organized with collections
Save and categorize content based on your preferences.
Serial
@Target([AnnotationTarget.FUNCTION, AnnotationTarget.PROPERTY_GETTER, AnnotationTarget.PROPERTY_SETTER, AnnotationTarget.FIELD]) class Serial
Indicates that an annotated field or method is part of the serialization mechanism defined by the Java Object Serialization Specification. This annotation type is intended to allow compile-time checking of serialization-related declarations, analogous to the checking enabled by the java.lang.Override
annotation type to validate method overriding. classes are encouraged to use annotations to help a compiler catch mis-declared serialization-related fields and methods, mis-declarations that may otherwise be difficult to detect.
Specifically, annotations of this type should be applied to serialization-related methods and fields in classes declared to be Serializable
. The five serialization-related methods are:
private void writeObject(java.io.ObjectOutputStream stream) throws IOException
private void readObject(java.io.ObjectInputStream stream) throws IOException, ClassNotFoundException
private void readObjectNoData() throws ObjectStreamException
- ANY-ACCESS-MODIFIER
Object writeReplace() throws ObjectStreamException
- ANY-ACCESS-MODIFIER
Object readResolve() throws ObjectStreamException
The two serialization-related fields are:
private static final ObjectStreamField[] serialPersistentFields
private static final long serialVersionUID
Compilers are encouraged to validate that a method or field marked with a
@Serial
annotation is one of the defined serialization-related methods or fields declared in a meaningful context and issue a warning if that is not the case.
It is a semantic error to apply this annotation to other fields or methods, including:
- fields or methods in a class that is not
Serializable
- fields or methods of the proper structural declaration, but in a type where they are ineffectual. For example,
enum
types are defined to have a serialVersionUID
of 0L
so a serialVersionUID
field declared in an enum
type is ignored. The five serialization-related methods identified above are likewise ignored for an enum
type.
- in a class that is
Externalizable
:
- method declarations of
writeObject
, readObject
, and readObjectNoData
- a field declaration for
serialPersistentFields
While the Externalizable
interface extends Serializable
, the three methods and one field above are not used for externalizable classes.
Note that serialization mechanism accesses its designated fields and methods reflectively and those fields and methods may appear otherwise unused in a
Serializable
class.
Summary
Public constructors |
Indicates that an annotated field or method is part of the serialization mechanism defined by the Java Object Serialization Specification.
|
Public constructors
Serial
Serial()
Indicates that an annotated field or method is part of the serialization mechanism defined by the Java Object Serialization Specification. This annotation type is intended to allow compile-time checking of serialization-related declarations, analogous to the checking enabled by the java.lang.Override
annotation type to validate method overriding. classes are encouraged to use annotations to help a compiler catch mis-declared serialization-related fields and methods, mis-declarations that may otherwise be difficult to detect.
Specifically, annotations of this type should be applied to serialization-related methods and fields in classes declared to be Serializable
. The five serialization-related methods are:
private void writeObject(java.io.ObjectOutputStream stream) throws IOException
private void readObject(java.io.ObjectInputStream stream) throws IOException, ClassNotFoundException
private void readObjectNoData() throws ObjectStreamException
- ANY-ACCESS-MODIFIER
Object writeReplace() throws ObjectStreamException
- ANY-ACCESS-MODIFIER
Object readResolve() throws ObjectStreamException
The two serialization-related fields are:
private static final ObjectStreamField[] serialPersistentFields
private static final long serialVersionUID
Compilers are encouraged to validate that a method or field marked with a
@Serial
annotation is one of the defined serialization-related methods or fields declared in a meaningful context and issue a warning if that is not the case.
It is a semantic error to apply this annotation to other fields or methods, including:
- fields or methods in a class that is not
Serializable
- fields or methods of the proper structural declaration, but in a type where they are ineffectual. For example,
enum
types are defined to have a serialVersionUID
of 0L
so a serialVersionUID
field declared in an enum
type is ignored. The five serialization-related methods identified above are likewise ignored for an enum
type.
- in a class that is
Externalizable
:
- method declarations of
writeObject
, readObject
, and readObjectNoData
- a field declaration for
serialPersistentFields
While the Externalizable
interface extends Serializable
, the three methods and one field above are not used for externalizable classes.
Note that serialization mechanism accesses its designated fields and methods reflectively and those fields and methods may appear otherwise unused in a
Serializable
class.
Content and code samples on this page are subject to the licenses described in the Content License. Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
Last updated 2025-02-10 UTC.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Missing the information I need","missingTheInformationINeed","thumb-down"],["Too complicated / too many steps","tooComplicatedTooManySteps","thumb-down"],["Out of date","outOfDate","thumb-down"],["Samples / code issue","samplesCodeIssue","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-02-10 UTC."],[],[],null,["# Serial\n\nAdded in [API level 34](https://developer.android.com/guide/topics/manifest/uses-sdk-element.html#ApiLevels)\n\nSerial\n======\n\n```\n@Target([AnnotationTarget.FUNCTION, AnnotationTarget.PROPERTY_GETTER, AnnotationTarget.PROPERTY_SETTER, AnnotationTarget.FIELD]) class Serial\n```\n\n|---------------------|\n| [java.io.Serial](#) |\n\nIndicates that an annotated field or method is part of the [serialization mechanism](/reference/kotlin/java/io/Serializable) defined by the Java Object Serialization Specification. This annotation type is intended to allow compile-time checking of serialization-related declarations, analogous to the checking enabled by the [java.lang.Override](../lang/Override.html#) annotation type to validate method overriding. classes are encouraged to use annotations to help a compiler catch mis-declared serialization-related fields and methods, mis-declarations that may otherwise be difficult to detect.\n\nSpecifically, annotations of this type should be applied to serialization-related methods and fields in classes declared to be `Serializable`. The five serialization-related methods are:\n\n- `private void writeObject(java.io.ObjectOutputStream stream) throws IOException`\n- `private void readObject(java.io.ObjectInputStream stream) throws IOException, ClassNotFoundException`\n- `private void readObjectNoData() throws ObjectStreamException`\n- *ANY-ACCESS-MODIFIER* `Object writeReplace() throws ObjectStreamException`\n- *ANY-ACCESS-MODIFIER* `Object readResolve() throws ObjectStreamException`\n\nThe two serialization-related fields are:\n\n\u003c!-- --\u003e\n\n- `private static final ObjectStreamField[] serialPersistentFields`\n- `private static final long serialVersionUID`\n\nCompilers are encouraged to validate that a method or field marked with a `@Serial` annotation is one of the defined serialization-related methods or fields declared in a meaningful context and issue a warning if that is not the case.\n\nIt is a semantic error to apply this annotation to other fields or methods, including:\n\n- fields or methods in a class that is not `Serializable`\n- fields or methods of the proper structural declaration, but in a type where they are ineffectual. For example, `enum` types are defined to have a `serialVersionUID` of `0L` so a `serialVersionUID` field declared in an `enum` type is ignored. The five serialization-related methods identified above are likewise ignored for an `enum` type.\n- in a class that is `Externalizable`:\n - method declarations of `writeObject`, `readObject`, and `readObjectNoData`\n - a field declaration for `serialPersistentFields`\n\n While the `Externalizable` interface extends `Serializable`, the three methods and one field above are *not* used for externalizable classes.\n\nNote that serialization mechanism accesses its designated fields and methods reflectively and those fields and methods may appear otherwise unused in a `Serializable` class.\n\nSummary\n-------\n\n| Public constructors ||\n|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|\n| [Serial](#Serial())`()` Indicates that an annotated field or method is part of the [serialization mechanism](/reference/kotlin/java/io/Serializable) defined by the Java Object Serialization Specification. |\n\nPublic constructors\n-------------------\n\n### Serial\n\nAdded in [API level 34](https://developer.android.com/guide/topics/manifest/uses-sdk-element.html#ApiLevels) \n\n```\nSerial()\n```\n\nIndicates that an annotated field or method is part of the [serialization mechanism](/reference/kotlin/java/io/Serializable) defined by the Java Object Serialization Specification. This annotation type is intended to allow compile-time checking of serialization-related declarations, analogous to the checking enabled by the [java.lang.Override](../lang/Override.html#) annotation type to validate method overriding. classes are encouraged to use annotations to help a compiler catch mis-declared serialization-related fields and methods, mis-declarations that may otherwise be difficult to detect.\n\nSpecifically, annotations of this type should be applied to serialization-related methods and fields in classes declared to be `Serializable`. The five serialization-related methods are:\n\n- `private void writeObject(java.io.ObjectOutputStream stream) throws IOException`\n- `private void readObject(java.io.ObjectInputStream stream) throws IOException, ClassNotFoundException`\n- `private void readObjectNoData() throws ObjectStreamException`\n- *ANY-ACCESS-MODIFIER* `Object writeReplace() throws ObjectStreamException`\n- *ANY-ACCESS-MODIFIER* `Object readResolve() throws ObjectStreamException`\n\nThe two serialization-related fields are:\n\n\u003c!-- --\u003e\n\n- `private static final ObjectStreamField[] serialPersistentFields`\n- `private static final long serialVersionUID`\n\nCompilers are encouraged to validate that a method or field marked with a `@Serial` annotation is one of the defined serialization-related methods or fields declared in a meaningful context and issue a warning if that is not the case.\n\nIt is a semantic error to apply this annotation to other fields or methods, including:\n\n- fields or methods in a class that is not `Serializable`\n- fields or methods of the proper structural declaration, but in a type where they are ineffectual. For example, `enum` types are defined to have a `serialVersionUID` of `0L` so a `serialVersionUID` field declared in an `enum` type is ignored. The five serialization-related methods identified above are likewise ignored for an `enum` type.\n- in a class that is `Externalizable`:\n - method declarations of `writeObject`, `readObject`, and `readObjectNoData`\n - a field declaration for `serialPersistentFields`\n\n While the `Externalizable` interface extends `Serializable`, the three methods and one field above are *not* used for externalizable classes.\n\nNote that serialization mechanism accesses its designated fields and methods reflectively and those fields and methods may appear otherwise unused in a `Serializable` class. \n**See Also**\n\n- [java.io.Serializable](/reference/kotlin/java/io/Serializable)\n- [java.io.Externalizable](/reference/kotlin/java/io/Externalizable)"]]