JavaIO字符操作和对象操作示例详解.docxVIP

  • 0
  • 0
  • 约2.84千字
  • 约 4页
  • 2025-06-09 发布于四川
  • 举报

JavaIO字符操作和对象操作示例详解

目录字符操作编码与解码String的编码方式Reader与Writer实现逐行输出文本文件的内容对象操作序列化Serializabletransient

字符操作

编码与解码

编码就是把字符转换为字节,而解码是把字节重新组合成字符。

如果编码和解码过程使用不同的编码方式那么就出现了乱码。

GBK编码中,中文字符占2个字节,英文字符占1个字节;UTF-8编码中,中文字符占3个字节,英文字符占1个字节;UTF-16be编码中,中文字符和英文字符都占2个字节。

UTF-16be中的be指的是BigEndian,也就是大端。相应地也有UTF-16le,le指的是LittleEndian,也就是小端。

Java的内存编码使用双字节编码UTF-16be,这不是指Java只支持这一种编码方式,而是说char这种类型使用UTF-16be进行编码。char类型占16位,也就是两个字节,Java使用这种双字节编码是为了让一个中文或者一个英文都能使用一个char来存储。

String的编码方式

String可以看成一个字符序列,可以指定一个编码方式将它编码为字节序列,也可以指定一个编码方式将一个字节序列解码为String。

Stringstr1=中文;

byte[]bytes=str1.getBytes(UTF-8);

Stringstr2=newString(bytes,UTF-8);

System.out.println(str2);

在调用无参数getBytes()方法时,默认的编码方式不是UTF-16be。双字节编码的好处是可以使用一个char存储中文和英文,而将String转为bytes[]字节数组就不再需要这个好处,因此也就不再需要双字节编码。getBytes()的默认编码方式与平台有关,一般为UTF-8。

byte[]bytes=str1.getBytes();

Reader与Writer

不管是磁盘还是网络传输,最小的存储单元都是字节,而不是字符。但是在程序中操作的通常是字符形式的数据,因此需要提供对字符进行操作的方法。

InputStreamReader实现从字节流解码成字符流;OutputStreamWriter实现字符流编码成为字节流。

实现逐行输出文本文件的内容

publicstaticvoidreadFileContent(StringfilePath)throwsIOException{

FileReaderfileReader=newFileReader(filePath);

BufferedReaderbufferedReader=newBufferedReader(fileReader);

Stringline;

while((line=bufferedReader.readLine())!=null){

System.out.println(line);

//装饰者模式使得BufferedReader组合了一个Reader对象

//在调用BufferedReader的close()方法时会去调用Reader的close()方法

//因此只要一个close()调用即可

bufferedReader.close();

对象操作

序列化

序列化就是将一个对象转换成字节序列,方便存储和传输。

序列化:ObjectOutputStream.writeObject()反序列化:ObjectInputStream.readObject()

不会对静态变量进行序列化,因为序列化只是保存对象的状态,静态变量属于类的状态。

Serializable

序列化的类需要实现Serializable接口,它只是一个标准,没有任何方法需要实现,但是如果不去实现它的话而进行序列化,会抛出异常。

publicstaticvoidmain(String[]args)throwsIOException,ClassNotFoundException{

Aa1=newA(123,abc);

StringobjectFile=file/a1;

ObjectOutputStreamobjectOutputStream=newObjectOu

文档评论(0)

1亿VIP精品文档

相关文档