文档章节

JavaIO<4>--ObjectInputStream和ObjectOutputStream

Credo-Zhao
 Credo-Zhao
发布于 2014/11/12 11:12
字数 655
阅读 30
收藏 0

ObjectInputStream 和 ObjectOutputStream 介绍

ObjectInputStream 和 ObjectOutputStream 的作用是,对基本数据和对象进行序列化操作支持
创建“文件输出流”对应的ObjectOutputStream对象,该ObjectOutputStream对象能提供对“基本数据或对象”的持久存储;当我们需要读取这些存储的“基本数据或对象”时,可以创建“文件输入流”对应的ObjectInputStream,进而读取出这些“基本数据或对象”。
注意: 只有支持 java.io.Serializable 或 java.io.Externalizable 接口的对象才能被ObjectInputStream/ObjectOutputStream所操作!

ObjectOutputStream 函数列表

// 构造函数  
ObjectOutputStream(OutputStream output)  
// public函数  
void     close()  
void     defaultWriteObject()  
void     flush()  
ObjectOutputStream.PutField     putFields()  
void     reset()  
void     useProtocolVersion(int version)  
void     write(int value)  
void     write(byte[] buffer, int offset, int length)  
void     writeBoolean(boolean value)  
void     writeByte(int value)  
void     writeBytes(String value)  
void     writeChar(int value)  
void     writeChars(String value)  
void     writeDouble(double value)  
void     writeFields()  
void     writeFloat(float value)  
void     writeInt(int value)  
void     writeLong(long value)  
final void     writeObject(Object object)  
void     writeShort(int value)  
void     writeUTF(String value)  
void     writeUnshared(Object object) 
ObjectInputStream 函数列表

// 构造函数  
ObjectInputStream(InputStream input)  
 
int     available()  
void     close()  
void     defaultReadObject()  
int     read(byte[] buffer, int offset, int length)  
int     read()  
boolean     readBoolean()  
byte     readByte()  
char     readChar()  
double     readDouble()  
ObjectInputStream.GetField     readFields()  
float     readFloat()  
void     readFully(byte[] dst)  
void     readFully(byte[] dst, int offset, int byteCount)  
int     readInt()  
String     readLine()  
long     readLong()  
final Object     readObject()  
short     readShort()  
String     readUTF()  
Object     readUnshared()  
int     readUnsignedByte()  
int     readUnsignedShort()  
synchronized void     registerValidation(ObjectInputValidation object, int priority)  
int     skipBytes(int length)

演示程序

package org.credo.jdk.io.ObjectStreamTest;

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.io.Serializable;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;

import org.apache.commons.lang.builder.EqualsBuilder;
import org.apache.commons.lang.builder.HashCodeBuilder;
import org.apache.commons.lang.builder.ToStringBuilder;

public class ObjectStreamTest
{

	public static void main(String[] args)
	{
		try
		{
			testWrite();
			testRead();
		} catch (IOException | ClassNotFoundException e)
		{
			e.printStackTrace();
		}
	}

	private static final String TMP_FILE = "computer.tmp";
	

	public static void testWrite() throws FileNotFoundException, IOException
	{
		ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream(TMP_FILE));
		out.writeBoolean(true);
		out.writeByte((byte) 65);
		out.writeChar('a');
		out.writeInt(20131015);
		out.writeFloat(3.14F);
		out.writeDouble(1.414D);
		// 写入HashMap对象  
        HashMap<String,String> map = new HashMap<>();  
        map.put("one", "red");  
        map.put("two", "green");  
        map.put("three", "blue");  
        out.writeObject(map);  
        // 写入自定义的Computer对象,Computer实现了Serializable接口  
        Computer computer=new Computer(1, 5666.66, "Y480");
        out.writeObject(computer);
        out.close();
	}
	
	@SuppressWarnings("rawtypes")
	public static void testRead() throws FileNotFoundException, IOException, ClassNotFoundException
	{
		ObjectInputStream in=new ObjectInputStream(new FileInputStream(TMP_FILE));
		System.out.printf("boolean:%b\n" , in.readBoolean());  
        System.out.printf("byte:%d\n" , (in.readByte()&0xff));  
        System.out.printf("char:%c\n" , in.readChar());  
        System.out.printf("int:%d\n" , in.readInt());  
        System.out.printf("float:%f\n" , in.readFloat());  
        System.out.printf("double:%f\n" , in.readDouble());
        
        // 读取HashMap对象  
        HashMap map = (HashMap) in.readObject();
        Iterator iterator=map.entrySet().iterator();
        while (iterator.hasNext())
		{
			Map.Entry mapEntry = (Map.Entry) iterator.next();
			System.out.printf("%-6s -- %s\n" , mapEntry.getKey(), mapEntry.getValue());
		}
        
        //读取Computer
        Computer computer=(Computer)in.readObject();
        System.out.println("computer: " + computer);
        in.close();
	}

}

class Computer implements Serializable
{

	private static final long serialVersionUID = -6347513352513264586L;

	private int id;
	private double price;
	private String name;
	
	public Computer(int id,double price,String name) {
		this.id=id;
		this.price=price;
		this.name=name;
	}

	public int getId()
	{
		return id;
	}

	public void setId(int id)
	{
		this.id = id;
	}

	public double getPrice()
	{
		return price;
	}

	public void setPrice(double price)
	{
		this.price = price;
	}

	public String getName()
	{
		return name;
	}

	public void setName(String name)
	{
		this.name = name;
	}

	@Override
	public int hashCode()
	{
		return HashCodeBuilder.reflectionHashCode(this);
	}

	@Override
	public boolean equals(Object obj)
	{
		return EqualsBuilder.reflectionEquals(this, obj);
	}

	@Override
	public String toString()
	{
		return ToStringBuilder.reflectionToString(this);
	}

}

输出

boolean:true
byte:65
char:a
int:20131015
float:3.140000
double:1.414000
three  -- blue
two    -- green
one    -- red
computer: org.credo.jdk.io.ObjectStreamTest.Computer@4935b92e[id=1,price=5666.66,name=Y480]


© 著作权归作者所有

Credo-Zhao

Credo-Zhao

粉丝 310
博文 168
码字总数 246058
作品 0
朝阳
技术主管
私信 提问
java的输入输出_将字符串写入文本文件

一、Filewriter与File——-将字符串写入文本文件 public static void main(String[] args) { } 二、InputStream与OutputStream 输入与输出串流 public static void main(String args[]){ pu......

huguzhang的博客
2017/12/16
0
0
Java IO类库之ObjectInputStream和ObjectOutPutStream

一、ObjectOutputStream 1 - ObjectOuputStream介绍 ObjectOutputStream(对象字节输出流),用于将一个序列化对象写入到创建ObjectOutputStream时传入的底层字节输入流中,通过源码可知该类继...

老韭菜
2018/07/21
20
0
Java 使用 ObjectStream 时的注意事项

在向下阅读之前,请注意 JavaBean 要实现 Serializable 接口。 初始化时发生了什么? ObjectOutputStream 初始化时会送出其 header 数据给对端。ObjectInputStream 初始化时会阻塞地接收来自...

傅易
2016/12/12
49
0
序列化中关于继承

实验1 结论: 如果Super类包含需要序列化的primitive类型变量,应该实现writeObject()和readObject()方法,并在里面分别调用ObjectOutputStream.defaultWriteObject()和ObjectInputStream.d...

Winchell
2016/12/14
9
0
obj 《---》byte[] 《---》ByteBuffer

1:将一个对象转化为写入:二进制数组缓冲区byte[]、写入一个文件等。 =======>写入缓冲区===== HostAndThreadNum hostAndThreadNum = new HostAndThreadNum("hadoop1",3);//定义一个缓冲区。......

刘付kin
2016/12/08
3
0

没有更多内容

加载失败,请刷新页面

加载更多

UAVStack功能上新:新增JVM监控分析工具

UAVStack推出的JVM监控分析工具提供基于页面的展现方式,以图形化的方式展示采集到的监控数据;同时提供JVM基本参数获取、内存dump、线程分析、内存分配采样和热点方法分析等功能。 引言 作为...

宜信技术学院
2分钟前
1
0
MySQL的5种时间类型的比较

日期时间类型 占用空间 日期格式 最小值 最大值 零值表示 DATETIME 8 bytes YYYY-MM-DD HH:MM:SS 1000-01-01 00:00:00 9999-12-31 23:59:59 0000-00-00 00:00:00 TIMESTAMP 4 bytes YYYY-MM......

物种起源-达尔文
9分钟前
3
0
云服务OpenAPI的7大挑战,架构师如何应对?

阿里妹导读:API 是模块或者子系统之间交互的接口定义。好的系统架构离不开好的 API 设计,而一个设计不够完善的 API 则注定会导致系统的后续发展和维护非常困难。比较好的API设计样板可以参...

阿里云官方博客
13分钟前
1
0
Rancher + VMware PKS实现全球数百站点的边缘K8S集群管理

Sovereign Systems是一家成立于2007年的技术咨询公司,帮助客户将传统数据中心技术和应用程序转换为更高效的、基于云的技术平台,以更好地应对业务挑战。曾连续3年提名CRN,并且在2012年到2...

RancherLabs
17分钟前
1
0
6、根据坐标,判断该坐标是否在地图区域范围内

最近在写配送区域相关的代码,具体需求如下: 根据腾讯地图划分配送区域,总站下边设多个配送分站,然后将订单中的收货地址将其分配给不同的配送分站。 1、地图区域划分(腾讯地图) 1.1、H...

有一个小阿飞
19分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部