I/O流之字符流

问题:字节流和字符流区别?

java1.0只提供了字节流,分为输出流(Inputstream)和输入流(Outputstream),

以字节为单位来读取或写入数据,以二进制来处理数据(8位),但无法处理Unicode字符。

java1.1版本增加了字符流Reader(输入流)和Writer(输出流),可以解决16位的

Unicode字符。

所以最好用字符流

(Unicode字符:可以在二进制和字符间相互转换的一种编码机制或准则)

//读取文件并复制文件
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException; public class FileWriteTest{ public static void main(String[] args) { try{
FileReader finput=new FileReader("桌面\\递归");//产生输入流
FileWriter Foutput=new FileWriter("桌面\\递归副本");//产生输出流 int i=0;
while((i=finput.read())!=-1){
System.out.print((char)i);
Foutput.write(i);
}
finput.close(); Foutput.flush();
//**注意,Foutput,调用flush()方法来强制写出所有缓冲区的数据,清空缓冲区
Foutput.close(); }catch(FileNotFoundException e){
e.printStackTrace();
}catch (IOException e) {
e.printStackTrace();
}
}
}
/*运行结果:无法找到文件,为什么?
java.io.FileNotFoundException: 桌面\递归 (No such file or directory)
at java.io.FileInputStream.open0(Native Method)
at java.io.FileInputStream.open(FileInputStream.java:195)
at java.io.FileInputStream.<init>(FileInputStream.java:138)
at java.io.FileInputStream.<init>(FileInputStream.java:93)
at java.io.FileReader.<init>(FileReader.java:58)
at FileWriteTest.main(FileWriteTest.java:11)
*/

说明:如果要输出流写数据,需要在写入操作完成后,调用flush()方法来强制写出所有缓冲区的数据

I/O原理

数据源———输入流——>java程序读取数据

java程序写入数据———输出流——>数据源(存储媒介)

说明:

数据源:比如文件、内存、网络连接

流的分类:

数据流:输入流和输出流(读取和输出)

数据传输单位:字节流 (InputStream和OutputSteam)和字符流(Writer和Reader)

按功能分:过滤流(直接操作数据源的流)和节点流(对已存在的流进行读写和封装,为通过更强大的读写功能)

缓冲流和对象流

缓冲流的应用场景?(读大文件时,可以增加读写效率,用BufferReader来读)

当文件大的时候,肯定用字符流读会很不便捷,则需要用过滤流,也叫处理流,即对一个已存在的流进行连接和封装,并为了扩展其读写功能。而缓冲流就是其中一种。

缓冲流:直接操作一个数据源的节点流的一个包装。

例如把

FileReader finput=new FileReader("桌面\\递归");//产生输入流

改为

BufferReader finput=new BufferReader("桌面\\递归");

此时读取的效率会更高

对象流的应用场景?

对象流也是过滤流的一种,主要有ObjectOutputStream类和ObjectInputStream类,用于存和读基本类型数据或对象的过滤流,特点是把java中的对象写到数据源中(序列化,即写入或者理解为存),也能把对象从数据源中还原出来(反序列化,解析或者读取)。

说明:

1.对象流不能序列化static或transit修饰的成员变量。

2.序列化的对象所对应的类那必须实现Java.io.Serializable接口。

比如:

import Java.io.Serializable;

public class Student implements Serializable{

……

}

问题:

什么是不可序列化的对象呢?是不是这个对象本身就已经被写出来了呢?

static是修饰静态变量时,只要类加载即可,不需要读到数据源(文件、内存、网络连接)当中,即不需要序列化。

随机存储存取文件流和File类

1.随机存储存取文件流

RandomAccessFile是一种特殊的流类,它在文件任何地方读取或写入数据。

RandomAccessFile能在文件里随意地前后移动,它是一个直接继承于Object的类。

简单概括:文件内容可跳读、可间断下载(不连续)、储存

一般RandomAccessFile的工作方式是吧DataInputStream和DataOutputStream

结合起来,再加上一些自己的方法。

常用方法:

long getFilePointer();   //用于得到当前文件指针

void seek(long pos);    //用于移动文件指针到指定的位置

int   skipBytes(int n);   //使文件指针向前移动指定的n个字节,即跳过的字节数

2.File类

应用场景是什么?

操作某个文件夹或设置某个文件夹的属性或代表文件的概念,以及存储一些对于文件

的基本操作。

说明:其定义了一系列与操作系统平台无关的方法来操作文件和目录。

(查看API文档关于java.File类)

File文件或目录的生成

File类的对象可代表一个文件路径

File f1=new File(“d:\\test\\1.txt”);

//把以往的笔记看看,其实你之前花时间学过IO流的,不懂的位置参看一下蓝白书的例子,另外把红黄书的后面的题目做一下,宝典的对应的内容复习一下。

I/O复习的更多相关文章

  1. iOS总结_UI层自我复习总结

    UI层复习笔记 在main文件中,UIApplicationMain函数一共做了三件事 根据第三个参数创建了一个应用程序对象 默认写nil,即创建的是UIApplication类型的对象,此对象看成是 ...

  2. vuex复习方案

    这次复习vuex,发现官方vuex2.0的文档写得太简略了,有些看不懂了.然后看了看1.0的文档,感觉很不错.那以后需要复习的话,还是先看1.0的文档吧.

  3. 我的操作系统复习——I/O控制和系统调用

    上篇博客介绍了存储器管理的相关知识——我的操作系统复习——存储器管理,本篇讲设备管理中的I/O控制方式和操作系统中的系统调用. 一.I/O控制方式 I/O就是输入输出,I/O设备指的是输入输出设备和存 ...

  4. 复习(1)【Maven】

    终于开始复习旧知识了,有输入必然要有输出.输入和输出之间的内化过程尤为重要,在复习的同时,真正把学到的东西积淀下来,加深理解. Maven项目概念与配置 Maven是一个项目管理和综合工具.Maven ...

  5. 《CSS权威指南》基础复习+查漏补缺

    前几天被朋友问到几个CSS问题,讲道理么,接触CSS是从大一开始的,也算有3年半了,总是觉得自己对css算是熟悉的了.然而还是被几个问题弄的"一脸懵逼"... 然后又是刚入职新公司 ...

  6. JS复习--更新结束

    js复习-01---03 一 JS简介 1,文档对象模型 2,浏览器对象模型 二 在HTML中使用JS 1,在html中使用<script></script>标签 2,引入外部 ...

  7. jQuery 复习

    jQuery 复习 基础知识 1, window.onload $(function(){});   $(document).ready(function(){}); 只执行函数体重的最后一个方法,事 ...

  8. jQuery5~7章笔记 和 1~3章的复习笔记

    JQery-05 对表单和表格的操作及其的应用 JQery-06 jQuery和ajax的应用 JQery-07 jQuery插件的使用和写法 JQery-01-03 复习 之前手写的笔记.实在懒得再 ...

  9. HTML和CSS的复习总结

    HTML(Hypertext Markup Language)超文本标记语言:其核心就是各种标记!<html> HTML页面中的所有内容,都在该标签之内:它主要含<head>和 ...

  10. 2017年1月1日 java学习第二天复习

    今天是新年的第一天,以前学习没有总结习惯,学习效率和成果都很不好.  学习的过程就是反复的复习和不断学习的过程,开始今天的学习总结   学习java的第二天. 今天学习了java最基础的一些内容,照着 ...

随机推荐

  1. POJ--1050--To the Max(线性动规,最大子矩阵和)

    To the Max Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 44723 Accepted: 23679 Descript ...

  2. ZOJ 3777 - Problem Arrangement - [状压DP][第11届浙江省赛B题]

    题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3777 Time Limit: 2 Seconds      Me ...

  3. 大数据竞赛平台Kaggle案例实战

    Kaggle是由联合创始人.首席执行官安东尼·高德布卢姆(Anthony Goldbloom)2010年在墨尔本创立的,主要为开发商和数据科学家提供举办机器学习竞赛.托管数据库.编写和分享代码的平台. ...

  4. 表优化 altering table OPTIMIZE TABLE `sta_addr_copy`

    表优化 altering table OPTIMIZE TABLE `sta_addr_copy` [总结] 1.实际测试的结果是,在state sqlaltering table OPTIMIZE ...

  5. Mybatis插入数据后返回主键id

    有时候使用mybatis插入数据后,需要用到记录在数据库中的自增id,可以利用keyProperty来返回,赋值给实体类中的指定字段. 单条记录插入并返回 First, if your databas ...

  6. Vagrant入门一(转)

    原文: https://github.com/astaxie/Go-best-practice/blob/master/ebook/zh/01.2.md 1.2 Vagrant安装配置 实际上Vagr ...

  7. Python实现常用的逻辑数据结构

    逻辑数据结构包括:线形结构.树形结构.图形结构.集合:存储结构包括:顺序存储.链式存储.索引存储.散列存储. 同一种逻辑结构可以有四种存储结构,不同的存储结构增.删.查.改的速度不同.逻辑结构与存储结 ...

  8. CentOS关闭防火墙&SELinux

    须知: 防火墙配置文件:/etc/sysconfig/iptables 查看防火墙状态:service iptables status 关闭防火墙:service iptables stop 关闭ip ...

  9. 启动spark-shell

    $cd /app/hadoop/spark-1.1.0/bin $spark-shell --master spark://SPARK02:7077 --executor-memory 500m 特别 ...

  10. 12.预处理数据的方法总结(使用sklearn-preprocessing)

    https://blog.csdn.net/sinat_33761963/article/details/53433799