首先,应该明白的是transient是java中的一个关键字,音标为 英: [ˈtrænziənt]

  在了解transient关键字之前,应该先弄明白序列化和反序列化。所谓的序列化,通俗点的来说,就是将一个对象转化为字节序列的形式来表示,这些字节序列中包含了一个对象的相关属性信息。一个对象进行序列化之后,可以被存储到硬盘当中,也可以用于网络传输。而反序列化便是将一个对象的字节序列转化为原先的java对象,这个过程便是反序列化。

  在java中,transient关键字的作用是让被该transient关键字所修饰的成员属性不被序列化。

示例代码如下:

package other.serial;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable; /**
* 该类的代码用于演示transient关键字的使用
* @author 学徒
*
*/
public class Person implements Serializable
{
private String name="张红";
private String sex="女";
//女人的年龄是秘密,不能被外面的人知道
private transient int age=10;
//重载Object类的toString方法
@Override
public String toString()
{
return "姓名:"+this.name+" 性别:"+this.sex+" 年龄:"+this.age;
}
public static void main(String[] args)throws Exception
{
String path="H:\\xiaohonghong.obj";
//输出对象的信息并进行序列化操作
Person xiaohong=new Person();
System.out.println(xiaohong);
File output=new File(path);
FileOutputStream out=new FileOutputStream(output);
ObjectOutputStream outputObject=new ObjectOutputStream(out);
outputObject.writeObject(xiaohong); //进行反序列化操作并输出对象信息
File input=new File(path);
FileInputStream in=new FileInputStream(input);
ObjectInputStream inputObject=new ObjectInputStream(in);
xiaohong=(Person)inputObject.readObject();
System.out.println(xiaohong);
} } 运行结果:
姓名:张红 性别:女 年龄:10
姓名:张红 性别:女 年龄:0

至于为什么要不被序列化,其主要是为了节省存储空间,以及为了保证程序的整体逻辑

需要注意的是:

  1. transient关键字只能修饰变量,而不能修饰方法和类。注意,本地变量(即局部变量)是不能被transient关键字修饰的。
  2. 被transient关键字修饰的变量不再能被序列化,一个静态变量不管是否被transient修饰,均不能被序列化。

还有一点需要值得注意的是,在实现了Serializable接口的时候,其序列化过程是默认自动进行的,为此,被transient修饰符所修饰的成员变量不被序列化。而当使用Externalizable接口实现序列化操作的时候,其序列化过程是程序编写人员进行控制的,没有任何东西会进行自动的序列化,需要在writeExternal方法中进行手工指定所要序列化的变量,这与是否被transient修饰无关。

实例代码如下:

package other.serial;

import java.io.Externalizable;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectInputStream;
import java.io.ObjectOutput;
import java.io.ObjectOutputStream; /**
* 该类的代码用于演示transient关键字的使用
* @author 学徒
*
*/
public class Person implements Externalizable
{
private String name="张红";
private String sex="女";
//女人的年龄是秘密,不能被外面的人知道
private transient int age=10;
//重载Object类的toString方法
@Override
public String toString()
{
return "姓名:"+this.name+" 性别:"+this.sex+" 年龄:"+this.age;
}
public static void main(String[] args)throws Exception
{
String path="H:\\xiaohonghong.obj";
//输出对象的信息并进行序列化操作
Person xiaohong=new Person();
System.out.println(xiaohong);
File output=new File(path);
FileOutputStream out=new FileOutputStream(output);
ObjectOutputStream outputObject=new ObjectOutputStream(out);
outputObject.writeObject(xiaohong); //进行反序列化操作并输出对象信息
File input=new File(path);
FileInputStream in=new FileInputStream(input);
ObjectInputStream inputObject=new ObjectInputStream(in);
xiaohong=(Person)inputObject.readObject();
System.out.println(xiaohong);
}
/**
* 控制需要进行序列化的成员变量
*/
@Override
public void writeExternal(ObjectOutput out) throws IOException
{
out.writeObject(name);
out.writeObject(sex);
//女人的年龄虽然是个秘密,但是序列化我是个大嘴巴,我要告诉别人
out.writeInt(age);
}
/**
* 控制进行反序列化的成员变量
*/
@Override
public void readExternal(ObjectInput in) throws IOException,ClassNotFoundException
{
this.name=(String)in.readObject();
this.sex=(String)in.readObject();
//这样我就知道女人的年龄了
this.age=in.readInt();
} } 运行结果:
姓名:张红 性别:女 年龄:10
姓名:张红 性别:女 年龄:10

回到目录|·(工)·)

K:java序列化与反序列化—transient关键字的使用的更多相关文章

  1. Java基础(五)-Java序列化与反序列化

    .output_wrapper pre code { font-family: Consolas, Inconsolata, Courier, monospace; display: block !i ...

  2. java序列化和反序列化使用总结

    一.概念 java对象序列化的意思就是将对象的状态转化成字节流,以后可以通过这些值再生成相同状态的对象.对象序列化是对象持久化的一种实现方法,它是将对象的属性和方法转化为一种序列化的形式用于存储和传输 ...

  3. java序列化和反序列化及序列化方式

    平时我们在Java内存中的对象,是无 法进行IO操作或者网络通信的,因为在进行IO操作或者网络通信的时候,人家根本不知道内存中的对象是个什么东西,因此必须将对象以某种方式表示出来,即 存储对象中的状态 ...

  4. Java序列化及反序列化

    序列化概念: 1.Java序列化与反序列化  Java序列化是指把Java对象转换为字节序列的过程:而Java反序列化是指把字节序列恢复为Java对象的过程. 2.为什么需要序列化与反序列化 我们知道 ...

  5. Java 序列化和反序列化(一)Serializable 使用场景

    目录 Java 序列化和反序列化(一)Serializable 使用场景 1. 最简单的使用:Serializable 接口 2. 序列化 ID 的问题 3. 静态字段不会序列化 4. 屏蔽字段:tr ...

  6. Java序列化与反序列化

    Java序列化与反序列化是什么?为什么需要序列化与反序列化?如何实现Java序列化与反序列化?本文围绕这些问题进行了探讨. 1.Java序列化与反序列化 Java序列化是指把Java对象转换为字节序列 ...

  7. [转] Java序列化与反序列化

    原文地址:http://blog.csdn.net/wangloveall/article/details/7992448 Java序列化与反序列化是什么?为什么需要序列化与反序列化?如何实现Java ...

  8. java序列化与反序列化(转)

    Java序列化与反序列化是什么?为什么需要序列化与反序列化?如何实现Java序列化与反序列化?本文围绕这些问题进行了探讨. 1.Java序列化与反序列化 Java序列化是指把Java对象转换为字节序列 ...

  9. Java序列化与反序列化是什么?为什么需要序列化与反序列化?如何实现Java序列化与反序列化?

    Java序列化与反序列化是什么?为什么需要序列化与反序列化?如何实现Java序列化与反序列化?本文围绕这些问题进行了探讨.  1.Java序列化与反序列化  Java序列化是指把Java对象转换为字节 ...

随机推荐

  1. hdu 2669 Romantic 扩展欧几里得

    Now tell you two nonnegative integer a and b. Find the nonnegative integer X and integer Y to satisf ...

  2. mysql left join 几个意思

    left join 用于多表  >1个表比如select a.*,b.* from ta as a left join tb as b on a.aid=b.bid咱们就以实际的代码来查看一下. ...

  3. git学习资料包

    1.廖雪峰老师的git教程:https://www.liaoxuefeng.com    -----点击“GIT教程”开始学习 2.菜鸟教程git学习:http://www.runoob.com/gi ...

  4. Java设计模式之策略设计模式

    1.什么是-策略设计模式 在软件开发中常常遇到这种情况,实现某一个功能有多种算法或者策略,我们可以根据环境或者条件的不同选择不同的算法或者策略来完成该功能.如查找.排序等,一种常用的方法是硬编码(Ha ...

  5. Python爬虫(九)_非结构化数据与结构化数据

    爬虫的一个重要步骤就是页面解析与数据提取.更多内容请参考:Python学习指南 页面解析与数据提取 实际上爬虫一共就四个主要步骤: 定(要知道你准备在哪个范围或者网站去搜索) 爬(将所有的网站的内容全 ...

  6. spring boot系列03--spring security (基于数据库)登录和权限控制(上)

    这篇打算写一下登陆权限验证相关 说起来也都是泪,之前涉及权限的比较少所以这次准备起来就比较困难. 踩了好几个大坑,还好最终都一一消化掉(这是废话你没解决你写个什么劲

  7. Java内存管理(一)

    好久没有写博客了,深感羞愧,今天聊一下Java的内存管理 简单介绍 Java相比传统语言(C,C++)的一个优势在于其能够自己主动管理内存.从而将开发人员管理内存任务剥离开来. 本文大体描写叙述了J2 ...

  8. C++技术问题总结-第8篇 STL内存池是怎么实现的

    STL内存池机制,使用双层级配置器.第一级採用malloc.free,第二级视情况採用不同策略. 这样的机制从heap中要空间,能够解决内存碎片问题. 1.内存申请流程图     简要流程图例如以下. ...

  9. 掀起Azure AD的盖头来——深入理解Microsoft Graph应用程序和服务权限声明

    作者:陈希章 发表于 2017年7月12日 引子 这是一篇计划外的文章.我们都知道要进行Microsoft Graph的开发的话,需要进行应用程序注册.这个在此前我已经有专门的文章写过了.但这里存在一 ...

  10. linux应用态下的时间

    1.时间值 1.1 日历时间(UTC) 该值是自1 9 7 0年1月1日0 0 : 0 0 : 0 0以来国际标准时间( U T C)所经过的秒数累计值(早期的手册称 U T C为格林尼治标准时间) ...