• Java中的transient关键字是什么意思?


    Java中的transient关键字是什么意思?



    在Java中,transient 是一个关键字,用于修饰实例变量(成员变量)。当一个实例变量被声明为transient 时,它的值不会被持久化(即不会被序列化)。
    主要用途和含义如下:
    1. 序列化控制:transient 用于控制对象在被序列化为字节流(例如用于持久化或网络传输)时哪些字段应该被忽略,不被序列化。这对于需要保留一些敏感信息或不需要被序列化的信息很有用。
    2. 节省空间:有些字段可能包含临时状态或缓存数据,不需要被持久化,将它们声明为transient 可以节省存储空间和传输带宽。
    下面是一个示例,说明了transient 的用法:
    import java.io.Serializable;
    
    public class Person implements Serializable {
        private String name;
        private transient int age; // 声明age字段为transient,不会被序列化
    
        // 构造方法、getter和setter等省略
    
        @Override
        public String toString() {
            return "Person [name=" + name + ", age=" + age + "]";
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    在上述示例中,age 字段被声明为transient,这意味着在序列化Person对象时,age 字段的值不会被包含在序列化数据中。其他非transient字段(例如name)将被正常序列化。
    需要注意的是,如果使用transient 修饰的字段在反序列化时会被初始化为默认值,例如int 字段会被初始化为0。因此,在反序列化后,age 字段的值将是0,除非在类中进行了特殊处理来设置它的值。

    你说的序列化是什么意思?在平时的Java程序中体现在哪里?



    序列化是将对象的状态转换为可以存储或传输的格式的过程。在Java中,序列化通常指的是将对象转换为字节流的形式,以便可以将它们保存到文件、传输到网络上的其他计算机,或在不同的Java虚拟机之间进行通信。反序列化是将字节流重新转换为对象的过程。
    序列化在平时的Java程序中可以体现在以下几个方面:
    1. 对象的持久化:通过序列化,可以将对象保存到文件中,以便在程序重新启动时恢复对象的状态。这在需要长期保存对象状态的应用中很有用,如数据库缓存、配置文件、日志记录等。
    2. 网络通信:在客户端和服务器之间传输对象时,可以将对象序列化为字节流,然后通过网络传输。接收方可以将字节流反序列化为对象,从而实现跨网络的通信。
    3. 分布式计算:在分布式系统中,不同的节点之间需要传递数据和对象。通过序列化和反序列化,可以实现跨节点的数据传输和对象传递。
    4. 缓存:一些缓存库(如Redis)允许存储序列化的对象,以提高数据访问速度。通过序列化,可以将对象存储在缓存中,并在需要时快速检索。
    要使一个类可序列化,需要实现java.io.Serializable接口。这个接口没有方法,它只是一个标记接口,告诉Java虚拟机这个类可以被序列化。然后,可以使用Java的序列化工具,如ObjectOutputStream来将对象序列化为字节流,并使用ObjectInputStream来反序列化对象。
    以下是一个示例,演示了如何在Java中进行对象的序列化和反序列化:
    import java.io.*;
    
    public class SerializationExample {
        public static void main(String[] args) {
            // 创建一个可序列化的对象
            Person person = new Person("Alice", 30);
    
            // 将对象序列化到文件
            try (FileOutputStream fileOut = new FileOutputStream("person.ser");
                 ObjectOutputStream out = new ObjectOutputStream(fileOut)) {
                out.writeObject(person);
                System.out.println("对象已序列化");
            } catch (IOException e) {
                e.printStackTrace();
            }
    
            // 从文件中反序列化对象
            try (FileInputStream fileIn = new FileInputStream("person.ser");
                 ObjectInputStream in = new ObjectInputStream(fileIn)) {
                Person restoredPerson = (Person) in.readObject();
                System.out.println("从文件中反序列化的对象: " + restoredPerson);
            } catch (IOException | ClassNotFoundException e) {
                e.printStackTrace();
            }
        }
    }
    
    class Person implements Serializable {
        private String name;
        private int age;
    
        public Person(String name, int age) {
            this.name = name;
            this.age = age;
        }
    
        @Override
        public String toString() {
            return "Person [name=" + name + ", age=" + age + "]";
        }
    }
    
    • 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
    • 38
    • 39
    • 40
    • 41
    在上述示例中,Person类实现了Serializable接口,允许它的对象被序列化和反序列化。程序首先将一个Person对象序列化到文件,然后再从文件中反序列化回来,恢复对象的状态。

    序列化的输出是什么?



    序列化的输出是将一个对象转换为字节流的表示形式,通常是一系列字节。这个字节流可以保存到文件、传输到网络上的其他计算机,或者用于其他目的。序列化后的字节流是二进制数据,不是人类可读的文本。
    在上述示例中,当执行out.writeObject(person)时,Person对象被序列化并写入到文件"person.ser"中。序列化后的字节流将包含Person对象的字段值和有关对象类型的信息。
    由于序列化的输出是二进制数据,不容易以文本形式展示。如果您想查看序列化后的内容,可以使用工具或代码来将字节流转换回对象,并查看对象的字段值。在示例中,使用ObjectInputStream来从文件中读取字节流并反序列化为Person对象,然后打印对象的字符串表示形式。
    所以,序列化的输出是二进制数据,可以用于持久化、传输和存储对象,但不是以文本形式呈现的。

  • 相关阅读:
    ThreeJS – 如何提升three.js的渲染效果
    redis高可用
    【Java设计模式】六、代理模式:静态代理、JDK + CGLIB动态代理
    [Windows内核源码分析0] 引导过程(Phase0部分分析)
    R语言使用forestploter包绘制单组及双组森林图(2)(附有超详细备注)
    ndarray、dtype——数据分析(一)
    VSCode的C/C++开发 ===> Windows
    ‘Xcode Unable to execute command: Segmentation fault: 11‘
    【DBoW3】【DBoW3实践】【DBoW3的使用学习记录】
    npx expo start -c 屏幕白屏
  • 原文地址:https://blog.csdn.net/XRT_knives/article/details/133687400