转换流及对象的序列化

 

转换流

字符输入流Reader是面向字符的输入流的超类,字符输出流Writer是面向字符的输出流的超类。它们在java.io包中均为抽象类。

文件输入流FileReader和文件输出流FileReader,它们分别是InputStreamReader和OutputStramReader的子类,与文件InputStreamReader及OutoutStreamReader。

通常Reader所做的每个请求都会导致对底层字符或字节流进行相应的读取,而Writer所做的每个请求都会将其输出立即输入到底层字符或字节流,因此缓冲流BufferedReader/BufferedWriter的使用大大提高了传输效率。

其构造方法如下:

               Public BufferedReader(Reader in):创建使用默认大小的输入缓冲区的缓冲字符流;

               Public BufferedWriter(Writer out):创建使用默认大小的输出缓冲区的缓冲字符流。

               public BufferedReader(Reader in,int z):创建使用z大小的输入缓冲区的缓冲字符流,若z<=0,则抛出异常;

               Public BufferedWriter(Writer out,int z):创建一个使用z大小的输出缓冲区的缓冲字符流,若z<=0,抛出异常。

实例方法:

               Public String readline() throws IOException:读取一个文本行。

               Public void newline() throws IOException:写入一个行分隔符,行分隔符字符串由系统属性line.separator定义,并且不一定是一个单个新行(‘\n’)符。

对象序列化:

       对象输入流/输出流ObjectInputStream/ObjectOutputStream是输入流/输出流InputStream/OutputStream的直接子类,有接口ObjectInput/ObjectOutput ,ObjectStream Constents 连接。

实例方法:

       ObjectInputStream类的readObject():从ObjectInputStream中读取对象;

bjectOutputStream类的writeObject():向ObjectOutputStream中写入对象;

序列化是指把并行数据换成串行数据的处理过程,而对象序列化(Object Serialization)是指把对象的状态数据以字节流的形式进行处理。注意:只有实现了java.iu.Serilazable接口的类的对象才能进行序列化,并且接口的实现的类应该提供无参的构造方法,以供可能的反序列化操作,系统重建对象时重新调用。

注意:

     由静态关键字static和用transient关键字表明的属性均不被序列化。因为static属性为整个类所有,而非对象;transient意为“临时的,短暂的”,临时对象在序列化过程之后不被保存,因此,反序列化时不被调用,返回null。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值