File: ImproperSerialPF.java

package info (click to toggle)
openjdk-25 25.0.1%2B8-1~deb13u1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 825,408 kB
  • sloc: java: 5,585,680; cpp: 1,333,948; xml: 1,321,242; ansic: 488,034; asm: 404,003; objc: 21,088; sh: 15,106; javascript: 13,265; python: 8,319; makefile: 2,518; perl: 357; awk: 351; pascal: 103; exp: 83; sed: 72; jsp: 24
file content (37 lines) | stat: -rw-r--r-- 1,265 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
/*
 * @test /nodynamiccopyright/
 * @bug 8202056
 * @compile/ref=ImproperSerialPF.out -XDrawDiagnostics -Xlint:serial ImproperSerialPF.java
 */

import java.io.*;

class ImproperSerialPF implements Serializable {
    // Proper declaration of serialPersistentFields is:
    // private static final ObjectStreamField[] serialPersistentFields = ...
    public /*instance*/ Object serialPersistentFields = Boolean.TRUE;

    private static final long serialVersionUID = 42;

    static class LiteralNullSPF implements Serializable {
        private static final ObjectStreamField[] serialPersistentFields = null;

        private static final long serialVersionUID = 42;
    }

    // Casting obscures the simple syntactic null-check
    static class CastedNullSPF implements Serializable {
        private static final ObjectStreamField[] serialPersistentFields =
            (ObjectStreamField[])null;

        private static final long serialVersionUID = 42;
    }

    // Conditional obscures the simple syntactic null-check too
    static class ConditionalNullSPF implements Serializable {
        private static final ObjectStreamField[] serialPersistentFields =
            (true ? null : null);

        private static final long serialVersionUID = 42;
    }
}