java序列化2[实现Externalizable接口,可控序列化]

简介:  * java可控制对象序列化:选择对象属性序列化,可序列化时加入当前类外其他属性  * 1.实现Externalizable接口(此接口实现了Serializable接口约定)  * 2.序列化和反序列化  * 3.控制序列化就是有选择的序列化对象(属性)  * 4.在序列化过程中储存(序列化),其他非this对象包含的数据或this信息  * 5.实现java对象和字节序

 * java可控制对象序列化:选择对象属性序列化,可序列化时加入当前类外其他属性
 * 1.实现Externalizable接口(此接口实现了Serializable接口约定)
 * 2.序列化和反序列化
 * 3.控制序列化就是有选择的序列化对象(属性)
 * 4.在序列化过程中储存(序列化),其他非this对象包含的数据或this信息
 * 5.实现java对象和字节序列的转换
 * 6.将对象的字节序列(内存)持久化到磁盘(通常为文件),高并发session处理(减轻内存压力)
 * 7.网络传输对象的字节序列,两个进程实现远程网络通信,(所有数据类型,都以二进制序列形式在网络上传送(接受发送))
 * 8.实现Serializable接口的类采用默认的序列化方式
 * 9.静态变量(类变量)和transient修饰变量(不序列化属性修饰符),不被序列化

 解,见上片:java序列化1[实现Serializable接口]

实现Externalizable接口的实体类代码:

package com.pakege.b;

import java.io.Externalizable;
import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectOutput;
import java.util.Date;
/**
 * java可控制对象序列化:选择对象属性序列化,可序列化时加入当前类外其他属性
 * 1.实现Externalizable接口(此接口实现了Serializable接口约定)
 * 2.序列化和反序列化 
 * 3.控制序列化就是有选择的序列化对象(属性)
 * 4.在序列化过程中储存(序列化),其他非this对象包含的数据或this信息 
 * 5.实现java对象和字节序列的转换
 * 6.将对象的字节序列(内存)持久化到磁盘(通常为文件),高并发session处理(减轻内存压力)
 * 7.网络传输对象的字节序列,两个进程实现远程网络通信,(所有数据类型,都以二进制序列形式在网络上传送(接受发送))
 * 8.实现Serializable接口的类采用默认的序列化方式 
 * 9.静态变量(类变量)和transient修饰变量(不序列化属性修饰符),不被序列化
 * */
public class ExternalizableTest implements Externalizable{
	
	private static final long serialVersionUID = -4036467956431644864L;
	private int id;
	private String name;
	private String age;
	private double balance;
	//静态变量,不能被序列化
	private static String cardNo = "0102221992212**53";
	//transient修饰变量,不能被序列化
	private transient String gender;
	/**
	 * writerExternal方法在序列化时被调用
	 * 在该方法中控制序列化内容
	 * 选择性序列化(属性)
	 * */
	@Override
	public void writeExternal(ObjectOutput out) throws IOException {
		System.out.println("序列化writeExternal执行……");
		String addStr = "非this对象包含的数据";
		Date date = new Date();
		out.writeObject(date);
		System.out.println(date);
		out.writeObject(addStr);
		//序列化this的name和balance
		out.writeObject(this.getName());
		out.writeObject(this.getBalance());
	}
	/**
	 * readExternal方法在反序列时被调用
	 * 在该方法中控制反序列的内容 
	 * 按序列化顺序反序列化并封装对象返回
	 * */
	@Override
	public void readExternal(ObjectInput in) throws IOException,ClassNotFoundException {
		System.out.println("反序列化readExternal执行……");
		Date datei = (Date) in.readObject();
		String addi = (String) in.readObject();
		System.out.println(datei+"<->"+addi);
		this.setName((String)in.readObject());
		this.setBalance((double)in.readObject());
	} 
	//getter and setter
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public String getAge() {
		return age;
	}
	public void setAge(String age) {
		this.age = age;
	}
	public double getBalance() {
		return balance;
	}
	public void setBalance(double balance) {
		this.balance = balance;
	}
	public static String getCardNo() {
		return cardNo;
	}
	public static void setCardNo(String cardNo) {
		ExternalizableTest.cardNo = cardNo;
	}
	public String getGender() {
		return gender;
	}
	public void setGender(String gender) {
		this.gender = gender;
	}
}


测试代码:

package com.pakege.b;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.text.MessageFormat;

import org.junit.Test;

public class ExternalTest {
	//序列化
	@Test
	public void testO2B() throws FileNotFoundException, IOException{
		//准备序列化对象
		ExternalizableTest customer = new ExternalizableTest();
		customer.setId(55555);
		customer.setName("Tony");
		customer.setAge("24");
		customer.setGender("男");
		customer.setBalance(9876543210.25d);
		//序列化一个ExternalizableTest对象customer
		ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream(new File("D:/XXXXX/Customere.txt")));
		out.writeObject(customer);
		out.close();
	}
	//反序列化
	@Test
	public void testB2O() throws FileNotFoundException, IOException, ClassNotFoundException{
		//反序列化
		ObjectInputStream input = new ObjectInputStream(new FileInputStream(new File("D:/XXXXX/Customere.txt")));
		ExternalizableTest customer = (ExternalizableTest) input.readObject();
		System.out.println(MessageFormat.format("id={0},name={1},age={2},balance={3},cardNo={4},gender={5}", customer.getId(),
				customer.getName(),customer.getAge(),customer.getBalance(),customer.getCardNo(),customer.getGender()));
	}
}

测试结果:

序列化writeExternal执行……
Tue Jul 14 14:20:09 CST 2015

反序列化readExternal执行……
Tue Jul 14 14:20:09 CST 2015<->非this对象包含的数据
id=0,name=Tony,age=null,balance=9,876,543,210.25,cardNo=0102221992212**53,gender=null

 

 

目录
相关文章
|
1天前
|
Java 开发者
Java一分钟之-Lambda表达式与函数式接口
【5月更文挑战第12天】Java 8引入的Lambda表达式简化了函数式编程,与函数式接口结合,实现了代码高效编写。本文介绍了Lambda的基本语法,如参数列表、箭头符号和函数体,并展示了如何使用Lambda实现`Runnable`接口。函数式接口仅有一个抽象方法,可与Lambda搭配使用。`@FunctionalInterface`注解用于确保接口具有单一抽象方法。文章还讨论了常见的问题和易错点,如非函数式接口、类型冲突以及Lambda表达式的局部变量可见性,并提供了避免这些问题的策略。通过理解Lambda和函数式接口,开发者能提高代码可读性和效率。
16 4
|
2天前
|
安全 Java 调度
Java一分钟:多线程编程初步:Thread类与Runnable接口
【5月更文挑战第11天】本文介绍了Java中创建线程的两种方式:继承Thread类和实现Runnable接口,并讨论了多线程编程中的常见问题,如资源浪费、线程安全、死锁和优先级问题,提出了解决策略。示例展示了线程通信的生产者-消费者模型,强调理解和掌握线程操作对编写高效并发程序的重要性。
39 3
|
2天前
|
Java API
Java 接口
5月更文挑战第6天
|
2天前
|
存储 安全 Java
Java一分钟之-Map接口与HashMap详解
【5月更文挑战第10天】Java集合框架中的`Map`接口用于存储唯一键值对,而`HashMap`是其快速实现,基于哈希表支持高效查找、添加和删除。本文介绍了`Map`的核心方法,如`put`、`get`和`remove`,以及`HashMap`的特性:快速访问、无序和非线程安全。讨论了键的唯一性、`equals()`和`hashCode()`的正确实现以及线程安全问题。通过示例展示了基本操作和自定义键的使用,强调理解这些概念对编写健壮代码的重要性。
6 0
|
2天前
|
存储 安全 Java
Java一分钟之-集合框架进阶:Set接口与HashSet
【5月更文挑战第10天】本文介绍了Java集合框架中的`Set`接口和`HashSet`类。`Set`接口继承自`Collection`,特征是不允许重复元素,顺序不确定。`HashSet`是`Set`的实现,基于哈希表,提供快速添加、删除和查找操作,但无序且非线程安全。文章讨论了`HashSet`的特性、常见问题(如元素比较规则、非唯一性和线程安全性)以及如何避免这些问题,并提供了代码示例展示基本操作和自定义对象的使用。理解这些概念和注意事项能提升代码效率和可维护性。
9 0
|
2天前
|
存储 安全 算法
Java一分钟之-Java集合框架入门:List接口与ArrayList
【5月更文挑战第10天】本文介绍了Java集合框架中的`List`接口和`ArrayList`实现类。`List`是有序集合,支持元素重复并能按索引访问。核心方法包括添加、删除、获取和设置元素。`ArrayList`基于动态数组,提供高效随机访问和自动扩容,但非线程安全。文章讨论了三个常见问题:索引越界、遍历时修改集合和并发修改,并给出避免策略。通过示例代码展示了基本操作和安全遍历删除。理解并正确使用`List`和`ArrayList`能提升程序效率和稳定性。
7 0
|
3天前
|
Java
【JAVA进阶篇教学】第四篇:JDK8中函数式接口
【JAVA进阶篇教学】第四篇:JDK8中函数式接口
|
1天前
|
Java 调度
Java一分钟之线程池:ExecutorService与Future
【5月更文挑战第12天】Java并发编程中,`ExecutorService`和`Future`是关键组件,简化多线程并提供异步执行能力。`ExecutorService`是线程池接口,用于提交任务到线程池,如`ThreadPoolExecutor`和`ScheduledThreadPoolExecutor`。通过`submit()`提交任务并返回`Future`对象,可检查任务状态、获取结果或取消任务。注意处理`ExecutionException`和避免无限等待。实战示例展示了如何异步执行任务并获取结果。理解这些概念对提升并发性能至关重要。
15 5
|
1天前
|
安全 Java 调度
深入理解Java并发编程:线程安全与性能优化
【5月更文挑战第12天】 在现代软件开发中,多线程编程是提升应用程序性能和响应能力的关键手段之一。特别是在Java语言中,由于其内置的跨平台线程支持,开发者可以轻松地创建和管理线程。然而,随之而来的并发问题也不容小觑。本文将探讨Java并发编程的核心概念,包括线程安全策略、锁机制以及性能优化技巧。通过实例分析与性能比较,我们旨在为读者提供一套既确保线程安全又兼顾性能的编程指导。
|
2天前
|
Java
Java一分钟:线程协作:wait(), notify(), notifyAll()
【5月更文挑战第11天】本文介绍了Java多线程编程中的`wait()`, `notify()`, `notifyAll()`方法,它们用于线程间通信和同步。这些方法在`synchronized`代码块中使用,控制线程执行和资源访问。文章讨论了常见问题,如死锁、未捕获异常、同步使用错误及通知错误,并提供了生产者-消费者模型的示例代码,强调理解并正确使用这些方法对实现线程协作的重要性。
10 3