在Java中如何处理文本I/O

使用Scanner类读取文本数据,使用PrintWriter类写文本数据

例子:

public class IO {
public static void main(String [] args) throws FileNotFoundException { // PrintWriter printWriter = new PrintWriter("123.txt"); 输出文本数据
// printWriter.print("chenzquan");
// printWriter.close();
Scanner input = new Scanner(new File("123.txt")); //输入文本数据
System.out.print(input.nextLine()); }
}

文本I/O需要编码、解码而二进制I/O不需要,所以二进制I/O比较快

二进制I/O类

InputStream类的方法

OutputStream类方法

FileInputStream和FileOutputStream

FileInputStream类和FileOutputStream类用于从/向文件读取/写入字节

FileInputStream

FileOutputStream

public class TestFileStream {

    public static void main(String [] args) throws FileNotFoundException, IOException {
try(FileOutputStream fileOutputStream = new FileOutputStream("temp.dat");
){
for(int i=0;i<100; i++) {
fileOutputStream.write(i);
}
} try(FileInputStream fileInputStream = new FileInputStream("temp.dat");){
int value;
while((value=fileInputStream.read()) != -1) {
System.out.print(value + " ");
}
}
}
}

DataInputStream和DataOutputStresam

DataInputStream

实现DataInput接口

DataOutputStream

实现DataOutput接口

创建DataInputStream类和DataOutputStream类

例子:

例子:

public class TestDataStream {
public static void main(String [] args) throws FileNotFoundException, IOException {
try(DataOutputStream dataOutputStream = new DataOutputStream(new FileOutputStream("temp.dat"));){
dataOutputStream.writeUTF("John");
dataOutputStream.writeDouble(85.5); dataOutputStream.writeUTF("chenzquan");
dataOutputStream.writeDouble(100.0); } try(DataInputStream dataInputStream = new DataInputStream(new FileInputStream("temp.dat"));){
System.out.println(dataInputStream.readUTF() + " " + dataInputStream.readDouble());
System.out.println(dataInputStream.readUTF() + " " + dataInputStream.readDouble());
} }
}

DataInputStream类和DataOutputStream类以同机器平台无关的方式读写Java基本类型值和字符串,所以,一台机器写好数据,可以在另一台读取该文件

BufferedInputStream类和BufferedOutputStream类

他们可以通过减少磁盘读写次数提高输入和输出的速度

使用BufferedInputStream时,磁盘上的整块数据一次性地读入到内存中的缓冲区中,然后从缓冲区将个别数据传到程序中

使用BufferedOutputStream时,个别数据写进缓冲区,当缓冲区满了,缓冲区的数据一次性写入到磁盘中

对象I/O

ObjectInputStream类和ObjectOutputStream类可以用于读/写可序化的对象

ObjectInputStream类和ObjectOutputStreram类除了可以实现基本类型与字符串的输入和输出之外,还可以实现对象的输入和输出。

ObjectInputStream类和ObjectOutputStream类包含DataInputStream类和DataOutputStream类的所有功能,所以完全可以由ObjectInputStream类和ObjectOutputStream类代替DataInputStream类和DataOutputStream类

ObjectInputStream类

ObjectOutputStream类

他们的构建方法:

例子:

public class TestOjbectOutputStream {

    public static void main(String [] args) throws FileNotFoundException, IOException {

        try(ObjectOutputStream objectOutputStream = new ObjectOutputStream(new FileOutputStream("object.dat"));){
objectOutputStream.writeUTF("John");
objectOutputStream.writeDouble(85.5);
objectOutputStream.writeObject(new Date());
}
}
}
public class TestObjectInputStream {
public static void main(String [] args) throws FileNotFoundException, IOException, ClassNotFoundException { try(ObjectInputStream inputStream = new ObjectInputStream(new FileInputStream("object.dat"));){
String name = inputStream.readUTF();
double score = inputStream.readDouble();
Date date = (Date) inputStream.readObject(); System.out.println(name + " " + score + " " + date);
} }
}

可以向数据流中写入多个对象或基本类型数据。从对应的ObjectIutputStream中读回这些对象时,必须与其写入的类型和顺序相同。

为了得到所需的类型,必须使用java安全的类型转换。

Serializable接口

不是每个对象都可以写到输出流。可以写入输出流中的对象称为可序列化的。因为可序列化的对象是Serializable接口的实例,所以,可序列化对象必须实现Serializable接口。

Java提供一个内在机制自动完成写对象的过程,这过程称为对象序列化,他是在ObjectOutputStream中实现的。相反的,读取对象的过程称为对象反序列化,他是在ObjectInputStream中实现的。

用transient 关键字 表示这个不用序列化

如果没有transient就会发生异常NotSerializableException

序列化数组

随机访问文件

RandomAccessFile类允许文件的任何位置进行数据的读写。

当创建RandomAccessFile时,可以指定两种模式(“r”或“rw”)之一。

例子:

例子:

public class TestRandomAccessFile {
public static void main(String [] args) throws FileNotFoundException, IOException {
try (RandomAccessFile input = new RandomAccessFile("input.dat", "rw");){ input.setLength(0); for(int i=0; i<200; i++) {
input.writeInt(i);
}
System.out.println("Current file number is " + input.length());
input.seek(0);
System.out.println(input.readInt()); input.seek(1*4);
System.out.println(input.readInt()); input.seek(4*9);
System.out.println(input.readInt()); input.writeInt(555);
input.seek(10*4);
System.out.println(input.readInt());
input.seek(input.length());
input.writeInt(999); System.out.println("the new length is " + input.length()); input.seek(10*4);
System.out.println("the eleventh number is " + input.readInt());
}
}
}

调用read()和write()方法都会使指针移动

Java 二进制I/O处理的更多相关文章

  1. Java 二进制与十六进制转换

    Java 二进制与十六进制转换 二进制转换十六进制 /** * @description 将二进制转换成16进制 * * @param buf * @return */ public static S ...

  2. Java二进制兼容性原理

    一.概述 现在的软件越来越依赖于不同厂商.作者开发的共享组件,组件管理也变得越来越重要.在这方面,一个极其重要的问题是类的不同版本的二进制兼容性,即一个类改变时,新版的类是否可以直接替换原来的类,却不 ...

  3. Java二进制指令代码解析

    http://www.blogjava.net/DLevin/archive/2011/09/13/358497.html http://blog.csdn.net/sum_rain/article/ ...

  4. java二进制表示形式与移位操作符

    java二进制表示形式 java中数字的二进制表示形式称为"有符号的二进制补码",下面先介绍原码,反码,补码. 编码 计算方法 原码 用最高位表示符号位,'1'表示负号,'0'表示 ...

  5. JAVA:二进制(原码 反码 补码),位运算,移位运算,约瑟夫问题(5)

    一.二进制,位运算,移位运算 1.二进制 对于原码, 反码, 补码而言, 需要注意以下几点: (1).Java中没有无符号数, 换言之, Java中的数都是有符号的; (2).二进制的最高位是符号位, ...

  6. 【编程之美】java二进制实现重建

    package com.cn.binarytree.utils; /** * @author 刘利娟 liulijuan132@gmail.com * @version 创建时间:2014年7月20日 ...

  7. java中Integer包装类的具体解说(java二进制操作,全部进制转换)

    程序猿都非常懒,你懂的! 今天为大家分享的是Integer这个包装类.在现实开发中,我们往往须要操作Integer,或者各种进制的转换等等.我今天就为大家具体解说一下Integer的使用吧.看代码: ...

  8. java二进制相关基础

    转载请注明原创出处,谢谢! 说在前面 之前在JVM菜鸟进阶高手之路十(基础知识开场白)的时候简单提到了二进制相关问题,最近在看RocketMQ的源码的时候,发现涉及二进制的内容蛮多,jdk源码里面也是 ...

  9. JAVA 二进制基础

    主要内容 1.十进制二进制互转 2.二进制的位运算 3.JDK内置的进制转换 4.JAVA中的进制 十进制二进制互转 57 111001 二进制的位运算:优点:特定情况下,计算方便,被支持面广泛. ① ...

随机推荐

  1. Linux开机自动挂载存储的两种方式

    登录服务器,给查看了下,发现确实是没有自动加载,df -h只能显示本地硬盘的分区,fdisk -l 还是能看到存储空间,这说明这个服务器连接存储是木有问题的. 输入history | grep mou ...

  2. MT【30】椭圆的第二定义解题

    问题:上式表示的区域是怎样的? 解答:利用椭圆第二定义易知当取等号时为椭圆,又令$y$趋向于$+\infty$时不等号不成立,故可以判断为椭圆内部区域. 评:利用mathmatics软件容易得到

  3. 洛谷P3959 宝藏(NOIP2017)(状压DP,子集DP)

    洛谷题目传送门 Dalao的题解多数是什么模拟退火.DFS剪枝.\(O(3^nn^2)\)的状压DP之类.蒟蒻尝试着把状压改进了一下使复杂度降到\(O(3^nn)\). 考虑到每条边的贡献跟它所在的层 ...

  4. 洛谷P1516 青蛙的约会(扩展欧几里德)

    洛谷题目传送门 很容易想到,如果他们相遇,他们初始的位置坐标之差\(x-y\)和跳的距离\((n-m)t\)(设\(t\)为跳的次数)之差应该是模纬线长\(l\)同余的,即\((n-m)t\equiv ...

  5. Python入门基础之循环

    如果计算机不能循环,那么它比人还笨,实际上它也确实比人笨.你之所以觉得计算机好厉害,是因为它快,guangzhoushenbo.com计算机可以在1秒钟内重复做一件事情成千上万次. Python学习交 ...

  6. HTML for android 移动小球

    <html> <head> <title>球</title> <style type="text/css"> .test ...

  7. BZOJ 3503 [CQOI2014]和谐矩阵

    题目链接 BZOJ 3503 题解 没想到--直接用暴力的\(O((nm)^3)\)算法,居然能过?! 高斯消元解异或方程组. #include <cstdio> #include < ...

  8. 【转】在单片机中,C语言的一些误用和总结!

    在学习单片机的时候才真正知道C语言是什么,它是来干什么的~但是C语言用到嵌入式只是它小小的一部分应用,还有很多地方呢. 我们是不是在写程序的时候,错误很多就算编译通过了也达不到我们预期的结果,完了自己 ...

  9. 机器学习&深度学习资料收集

    缘由 以下博客都是我在学习过程中看到的一些知识讲解非常好的博文,就不转载了,直接给出链接方便以后重复访问.有了自己的理解之后再重新整理资料发布吧 : ) sklearn系列 http://www.cn ...

  10. luogu4267 TamingtheHerd (dp)

    设f[i][j]为让前i天发生j次暴动需要改变的最少的值 则f[i][j]=min{f[k][j-1]+(x[k+1]!=0)+(x[k+2]!=1)+...+(x[i]!=(i-k-1))} $O( ...