transient修饰的变量可以被序列化吗?

看到网上很多博客都是写到transient修饰的变量不可以被序列化, 实际上其变量可以被序列化,《Java编程思想》上写的很清楚。

事实证明:看博客不如看书(看经典书籍),看书不如自己码代码验证

代码是借鉴别人的,为了验证问题,直接上代码:

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;

public class PasswordFormat implements Serializable {
    /**
     * 
     */
    private static final long serialVersionUID = 1L;
    private String name;
    private transient String password;
    public PasswordFormat(String name, String password) {
        this.name = name;
        this.password = password;
    }
    public PasswordFormat() {
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
    private void writeObject(ObjectOutputStream oos) throws IOException {//重写以下两个方法,完成序列化时password的加密和解密
        oos.defaultWriteObject();
        char a[]=this.password.toCharArray();
        String str="";
        for(int i=0;i<a.length;i++){
            a[i]+=i;
            str+=a[i];
        }//各项加i再逆置;
        StringBuilder sb = new StringBuilder(str);
        oos.writeObject(sb.reverse().toString());
    }
    private void readObject(ObjectInputStream ois)
            throws ClassNotFoundException, IOException {
        ois.defaultReadObject();
        String str = (String) ois.readObject();
        System.out.println("解密后:" + str);
        StringBuilder sb = new StringBuilder(str);
        sb.reverse();
        char a[]=sb.toString().toCharArray();
        str="";
        for(int i=0;i<a.length;i++){
            a[i]-=i;
            str+=a[i];
        }
        this.password = str;
    }

    @Override
    public String toString() {
        return "PasswordFormat [name=" + name + ", password=" + password + "]";
    }
    public static void serializeTemp(PasswordFormat ob,File file){
        try(
                ObjectOutputStream oos=new ObjectOutputStream(new FileOutputStream(file));
                ObjectInputStream ois=new ObjectInputStream(new FileInputStream(file));
                ){
            oos.writeObject(ob);
            oos.flush();
            System.out.println((PasswordFormat)ois.readObject());
        }catch(IOException | ClassNotFoundException e){
            e.printStackTrace();
        }
    }
    public static void main(String[] args) {
        PasswordFormat pf=new PasswordFormat("xcw","xcw12345678");
        File file=new File("./yj.txt");
        PasswordFormat.serializeTemp(pf,file);
    }
}
复制代码

上图可以看到,只要重写writeObject和readObject,

  • 非transinent修饰的变量使用defaultWriteObject()和defaultReadObject()进行序列化和反序列化
  • transient修饰的变量必须手动使用writeObject()和readObject()进行序列化和反序列化
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值