文档章节

JavaIO<4>--ObjectInputStream和ObjectOutputStream

Credo-Zhao
 Credo-Zhao
发布于 2014/11/12 11:12
字数 655
阅读 27
收藏 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
粉丝 309
博文 162
码字总数 242388
作品 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时传入的底层字节输入流中,通过源码可知该类继...

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

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

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

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

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

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

刘付kin
2016/12/08
3
0

没有更多内容

加载失败,请刷新页面

加载更多

Word Pattern(leetcode290)

Given a pattern and a string str, find if str follows the same pattern. Here follow means a full match, such that there is a bijection between a letter in pattern and a non-empt......

woshixin
13分钟前
0
0
Kubernetes 1.13.1快速升级

Kubernetes 1.13.1已经正式发布,快速升级(含国内镜像快速下载链接)包括升级kubeadm/kubectl/kubelet版本、拉取镜像、升级Kubernetes集群三个主要步骤。注意Kubernetes 1.12.3版本暂时不支...

openthings
16分钟前
1
0
多线程的实现方式

多线程是指 一个程序运行时,产生或使用了不止一个线程。 线程的生命周期是怎么样的,下面这张图我们可以看出些端倪: 这章我们主要讨论多线程实现的方式,基础知识部分我们可以下来再恶补。...

搬砖大侠
29分钟前
1
0
新人千万不要在 Windows 上使用 Ruby on Rails

标题:新人千万不要在 Windows 上使用 Ruby on Rails 副标题:鼓励新人在 Linux 和 Mac 上使用 Ruby on Rails ! 原则:要走寻常路,不要学美特斯邦伟! "在 Windows上 使用 Ruby on Rails "是...

Jason909
37分钟前
2
0
day177-2018-12-14-英语流利阅读-待学习

艾滋病的治愈方法是否触手可及? Daniel 2018-12-14 1.今日导读 几十年来,艾滋病一直是世界上最难对付的“超级绝症”之一,从人类历史上第一次诊断出艾滋病病例的 20 世纪 80 年代早期到 20...

飞鱼说编程
今天
9
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部