K:java序列化与反序列化—transient关键字的使用
首先,应该明白的是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
至于为什么要不被序列化,其主要是为了节省存储空间,以及为了保证程序的整体逻辑
需要注意的是:
- transient关键字只能修饰变量,而不能修饰方法和类。注意,本地变量(即局部变量)是不能被transient关键字修饰的。
- 被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关键字的使用的更多相关文章
- Java基础(五)-Java序列化与反序列化
.output_wrapper pre code { font-family: Consolas, Inconsolata, Courier, monospace; display: block !i ...
- java序列化和反序列化使用总结
一.概念 java对象序列化的意思就是将对象的状态转化成字节流,以后可以通过这些值再生成相同状态的对象.对象序列化是对象持久化的一种实现方法,它是将对象的属性和方法转化为一种序列化的形式用于存储和传输 ...
- java序列化和反序列化及序列化方式
平时我们在Java内存中的对象,是无 法进行IO操作或者网络通信的,因为在进行IO操作或者网络通信的时候,人家根本不知道内存中的对象是个什么东西,因此必须将对象以某种方式表示出来,即 存储对象中的状态 ...
- Java序列化及反序列化
序列化概念: 1.Java序列化与反序列化 Java序列化是指把Java对象转换为字节序列的过程:而Java反序列化是指把字节序列恢复为Java对象的过程. 2.为什么需要序列化与反序列化 我们知道 ...
- Java 序列化和反序列化(一)Serializable 使用场景
目录 Java 序列化和反序列化(一)Serializable 使用场景 1. 最简单的使用:Serializable 接口 2. 序列化 ID 的问题 3. 静态字段不会序列化 4. 屏蔽字段:tr ...
- Java序列化与反序列化
Java序列化与反序列化是什么?为什么需要序列化与反序列化?如何实现Java序列化与反序列化?本文围绕这些问题进行了探讨. 1.Java序列化与反序列化 Java序列化是指把Java对象转换为字节序列 ...
- [转] Java序列化与反序列化
原文地址:http://blog.csdn.net/wangloveall/article/details/7992448 Java序列化与反序列化是什么?为什么需要序列化与反序列化?如何实现Java ...
- java序列化与反序列化(转)
Java序列化与反序列化是什么?为什么需要序列化与反序列化?如何实现Java序列化与反序列化?本文围绕这些问题进行了探讨. 1.Java序列化与反序列化 Java序列化是指把Java对象转换为字节序列 ...
- Java序列化与反序列化是什么?为什么需要序列化与反序列化?如何实现Java序列化与反序列化?
Java序列化与反序列化是什么?为什么需要序列化与反序列化?如何实现Java序列化与反序列化?本文围绕这些问题进行了探讨. 1.Java序列化与反序列化 Java序列化是指把Java对象转换为字节 ...
随机推荐
- 关于磁盘冗余阵列、热备、群集、负载均衡、云计算、F5、Nginx等的概念和基本原理
在系统部署实施过程中,客户往往会关注系统的可用性方面的指标. 对于一个具备高可用性的系统来说, 多机部署方案是必不可少的. 我们这个知识分享,就从多个不同层面来介绍多机部署方案. ---------- ...
- 手动安装lump
教你编译PHP7 (nginx+mysql+php7) PHP7正式版已经发布,性能是PHP5.6的两倍! 操作系统: CentOS Linux, 6.5 64位服务器: 阿里云空的操作系统,我们从 ...
- XSS攻击原理及防御措施
概述 XSS攻击是Web攻击中最常见的攻击方法之一,它是通过对网页注入可执行代码且成功地被浏览器 执行,达到攻击的目的,形成了一次有效XSS攻击,一旦攻击成功,它可以获取用户的联系人列 表,然后向联系 ...
- MySQL安装(yum、二进制、源码)
MySQL安装(yum.二进制.源码) 目录 1.1 yum安装... 2 1.2 二进制安装-mysql-5.7.17. 3 1.2.1 准备工作... 3 1.2.2 解压.移动.授权... 3 ...
- 利用纯CSS美化checkbox和radio和滑动按钮的实现
W3C提供的CheckBox和radio的原始样式非常的丑,而且在不同的额浏览器表现还不一样,使用常规的方法添加样式没法进行修改样式 一, 单选按钮 <html> <head> ...
- jupyter的交互小工具-----ipyleaflet
ipyleaflet(一个用于创建简单的交互式地图的平移和缩放的库,ipyleaflet支持诸如多边形,标记和更一般的任何地理编码地理数据结构的注释) from ipyleaflet import M ...
- 毕达哥拉斯树(pythagorasTree)原理解析及canvas动画实现
以前就看到了这个东西,由于太忙了最近才有时间来实现这个; 该文章适合有一定 canvas 基础的人阅读; 首先说说他的原理: The construction of the Pythagoras tr ...
- hdu4893 Wow! Such Sequence!
线段树结点上保存一个一般的sum值,再同一时候保存一个fbsum,表示这个结点表示的一段数字若为斐波那契数时的和 当进行3操作时,仅仅用将sum = fbsum就可以 其它操作照常进行,仅仅是单点更新 ...
- 在Flex中推断是否在组件之外单击的技巧
在Flex中推断是否在组件之外单击的技巧 昨天在做Flex开发的时候.遇到了这样一种操作,之前也遇到过.那时的办法不是非常好,今天又碰上了类似的问题,先看一张图吧! watermark/2/text/ ...
- Vue深度学习(6)- 组件
使用组件 在Vue中,可以用 Vue.extend() 创建一个组件构造器: var MyComponent = Vue.extend({ template:'..........' //选项 }) ...