为了账号安全,请及时绑定邮箱和手机立即绑定

文件传输基础——Java IO流

难度入门
时长 2小时 0分
学习人数
综合评分9.67
660人评价 查看评价
9.9 内容实用
9.6 简洁易懂
9.5 逻辑清晰
  • 对子类对象进行反序列化操作时,如果其父类没有实现序列化接口,那么其父类构造函数会被调用,如果实现了序列化接口,反序列化时该父类可以直接从序列化时指定的用于存储的文件里读取数据

     

    10:47
    看视频
  • private transient int stuage

    该元素不会进行默认的序列化,但也可以自行完成这个元素的序列化


    07:42
    看视频
  • InputStreamReader/OutputStreamWriter构造方法需要 InputStream/OutputStream 的对象  , 可以设置编码。FileRead/Writer 构造方法直接是是 File 的对象 ,这样代码量相对较少,但创建时不可以设置编码,需要额外注意

    00:33
    看视频
  • BufferedInputStream & BufferedOutputStream

    这两个流类为IO提供了带缓冲区的操作,一般打开文件进行写入或读出操作时,都会加上缓冲,这种流模式提高了IO的性能

    FileOutputStream--->write()方法相当于一滴一滴地把水“转移”过去

    DataOutputStream--->writeXxx() 方法相当于一瓢一瓢把水“转移”过去

    BufferedOutputStream-->write() 相当于一瓢一瓢放到桶里,再从桶中倒入缸中,性能提高了

    要用.flush()刷新缓冲区,要不然写入不到文件当中去

    07:59
    看视频
  • 转:byte 类型 8 位,int 类型 32 位,为了避免数据转换错误,通过 & 0xff 将高 24 位清零
    FileInputStream.read() 单字节适合读取 小 文件
    FileInputStream.read(byte[] bytes,int star,int size) 字节数组适合读取 大 文件
    读取文件最常用的是批量读取int bytes = FileInputStream.read(buf, 0 , buf.length);
    FileInputStream文件输入
    单字节输入即不用数组。

    从in中批量读取字节,放入到buf这个字节数组中,
    从第0个位置开始放,最多放buf.length个
    返回的是读到字节的个数,fileName为方法的参数


    04:46
    看视频
  • FileOutputStream 实现了向文件中写出byte数据的方法,其.write()方法只能写8位

    输出流FileOutputStream fileout=new FileOutputStream("路径",文件原本内容处理方式(true为追加,false为覆盖。));

    如果路径所指文件不存在,则直接创建,如果存在,则删除后创建  

    用中间变量buf从源文件读取内容,向目标文件写入内容。

    11:38
    看视频
  • DataInputStream和DataOutputStream是对流的扩展,装饰模式,可以更方便的读写int,long,字符等类型的数据,读写完要记得.close()

    DataOutputStream    writeInt()/writeDouble()/writeUTF()


    10:06
    看视频
  • java.io.File类用于表示文件(目录)

    File类只用于表示文件(目录)的信息(名称、大小等),不能用于文件内容的访问


    RandomAccessFile java提供的对文件内容的访问,既可以读文件,也可以写文件。

    RandomAccessFile支持随机访问文件,可以访问文件的任意位置


    05:21
    看视频
  • File.list()方法用于列出当前目录下的子目录和文件,获取该目录下的所有文件 


    File.listFiles()返回的是直接子目录(文件)的抽象,获取该目录下所有文件和目录的绝对路径


    通过list()方法获取的结果:

    <!--此处有图片-->


    通过listFiles()方法获取的结果:

    <!--此处有图片-->

    图转自博客:bingguang1993

  • File file=new File("E:\\javaio\\imooc"),“\\”或“//”是中间的分隔符,也可以用File.separator。

    file.exists()跟其字面意思一样,用于判断文件知否存在

    file.mkdir()可以直接创建文件夹(E:\\javaio\\imooc),file.mkdirs()可以创建多级目录,file.createNewFile()可以直接创建文件("E:\\javaio\\日记1.txt"),配合exists做个if else判断比较好

    file.delete()删除

    file.isDirectory()判断是否是一个目录,是返回true,不是目录或者目录不存在返回false,file.isFile()判读是否是一个文件

    File file2=new File("E:\\javaio","日记1.txt")是另一个构造函数,第一个参数代表目录,第二个代表文件

    以下为几种File类中简单的方法

    10:22
    看视频
  • 1.Integer.toHexString(byte)把字节(转换成了int)以16进制的方式显示 ,byte转换成int相当于int后八位为byte原来的,后八位前24位加上24个0,


    2.Integer.toHexString(byte%0xff) 把前头的0取掉,只留下后八位


    3.转换成字节序列用的是项目默认的编码gbk,中文占用2个字节,英文占用1个字节


    4.byte[] byte=s.getBytes()是用默认编码,byte[] byte=s.getBytes(参数)是用参数指定的编码(参数为:“某种编码”)


    5.utf-8编码中文占用3个字节,英文占用1个字节


    6.java是双字节编码,utf-16be编码,字符串一个字符占两个字节, 中文占用2个字节,英文占用2个字节。


    7.当你的字节序列式某种编码时,这个时候想把字节序列变成字符串,也需要用这种编码方式,否则会出现乱码。String str1=new String(byte):用项目默认的编码,String str2=new String(byte,参数):用参数指定的编码。比如byte[] byte=String.getBytes("utf-8"),那么将此字节序列变成字符串就要用String str=new Stirng(byte,"utf-8")。用gbk编码的字节序列直接用第一种不指定编码参数的方法即可,因为默认的就是用gbk编码所以不用gbk编码


    8.文本文件就是字节序列,可以是任意编码的字节序列。如果我们在中文机器上直接创建文本文件,那么该文本文件只认识ansi编码,中文系统下,ansi编码代表gbk编码


    9.中文机器上你直接创建一个文本文件,那么它只能认识ansi编码(gbk),但是文本文件本身可以放各种编码,直接粘贴到中文机器上的无论编码是哪种它都认识,只不过在中文机器上直接创建时会有这个特殊性。


    10.某个项目的文本文件只认识项目指定的编码,换一种别的编码他就不认识了。比如你把用utf-8编码的A项目下的文本文件直接拷贝到使用默认编码gbk的B项目下,拷贝的文件里就会出现乱码,但如果只是把A项目文本文件中的内容拷贝到B项目下的文本文件中,他会自动进行转换

  • 一个类实现了序列化接口,那么其子类都可以进行序列化

  • package com.imooc.io;


    import java.io.FileInputStream;

    import java.io.ObjectInputStream;


    public class ObjectSeriaDemo1 {

    public static void main(String[] args) throws Exception{

    String file = "demo/obj.dat";

    //1.对象的序列化

    /*ObjectOutputStream oos = new ObjectOutputStream(

    new FileOutputStream(file));

    Student stu = new Student("10001", "张三", 20);

    oos.writeObject(stu);

    oos.flush();

    oos.close();*/

    ObjectInputStream ois = new ObjectInputStream(

    new FileInputStream(file));

    Student stu = (Student)ois.readObject();

    System.out.println(stu);

    ois.close();

    }


    }



  • package com.imooc.io;

    import java.io.Serializable;

    public class Student implements Serializable{

    private String stuno;

    private String stuname;

    //该元素不会进行jvm默认的序列化,也可以自己完成这个元素的序列化

    private transient int stuage;  

    public Student(String stuno, String stuname, int stuage) {

    super();

    this.stuno = stuno;

    this.stuname = stuname;

    this.stuage = stuage;

    }

    public String getStuno() {

    return stuno;

    }

    public void setStuno(String stuno) {

    this.stuno = stuno;

    }

    public String getStuname() {

    return stuname;

    }

    public void setStuname(String stuname) {

    this.stuname = stuname;

    }

    public int getStuage() {

    return stuage;

    }

    public void setStuage(int stuage) {

    this.stuage = stuage;

    }

    @Override

    public String toString() {

    return "Student [stuno=" + stuno + ", stuname=" + stuname + ", stuage="

    + stuage + "]";

    }

    private void writeObject(java.io.ObjectOutputStream s)

            throws java.io.IOException{

    s.defaultWriteObject();//把jvm能默认序列化的元素进行序列化操作

    s.writeInt(stuage);//自己完成stuage的序列化

    }

    private void readObject(java.io.ObjectInputStream s)

            throws java.io.IOException, ClassNotFoundException{

      s.defaultReadObject();//把jvm能默认反序列化的元素进行反序列化操作

      this.stuage = s.readInt();//自己完成stuage的反序列化操作

    }

    }

  •  

    java.io.File类用于表示文件(目录)

    File类只用于表示文件(目录)的信息(名称、大小等),不能用于文件内容的访问


    RandomAccessFile java提供的对文件内容的访问,既可以读文件,也可以写文件。

    RandomAccessFile支持随机访问文件,可以访问文件的任意位置


    (1)java文件模型

      在硬盘上的文件是byte byte byte存储的,是数据的集合

    (2)打开文件

      有两种模式"rw"(读写)  "r"(只读)

      RandomAccessFile raf = new RandomeAccessFile(file,"rw")

      文件指针,打开文件时指针在开头 pointer = 0;

    (3) 写方法

        raf.write(int)--->只写一个字节(后8位),同时指针指向下一个位置,准备再次写入

    (4)读方法

       int b = raf.read()--->读一个字节

    (5)文件读写完成以后一定要关闭(Oracle官方说明)



    序列化与基本类型序列化

    1)将类型int 转换成4byte或将其他数据类型转换成byte的过程叫序列化

         数据---->n byte

    2)反序列化

        将n个byte 转换成一个数据的过程

        nbyte ---> 数据

    3)RandomAccessFile提供基本类型的读写方法,可以将基本类型数据

       序列化到文件或者将文件内容反序列化为数据

     IO流(输入流、输出流)

     字节流、字符流

     1.字节流

     1)InputStream、OutputStream

        InputStream抽象了应用程序读取数据的方式

        OutputStream抽象了应用程序写出数据的方式 

     2)EOF = End   读到-1就读到结尾

     3)输入流基本方法

       int  b = in.read();读取一个字节无符号填充到int低八位.-1是 EOF

       in.read(byte[] buf) 

       in.read(byte[] buf,int start,int size)

    4)输出流基本方法

      out.write(int b)  写出一个byte到流,b的低8位

      out.write(byte[] buf)将buf字节数组都写入到流

      out.write(byte[] buf,int start,int size)

      

     5)FileInputStream--->具体实现了在文件上读取数据

     6)FileOutputStream 实现了向文件中写出byte数据的方法

     7)DataOutputStream/DataInputStream

        对"流"功能的扩展,可以更加方面的读取int,long,字符等类型数据

       DataOutputStream

            writeInt()/writeDouble()/writeUTF()


     8)BufferedInputStream&BufferedOutputStream

     这两个流类位IO提供了带缓冲区的操作,一般打开文件进行写入

     或读取操作时,都会加上缓冲,这种流模式提高了IO的性能

     从应用程序中把输入放入文件,相当于将一缸水倒入到另一个缸中:

     FileOutputStream--->write()方法相当于一滴一滴地把水“转移”过去

     DataOutputStream-->writeXxx()方法会方便一些,相当于一瓢一瓢把水“转移”过去

     BufferedOutputStream--->write方法更方便,相当于一飘一瓢先放入桶中,再从桶中倒入到另一个缸中,性能提高了

       

       

     2.字符流

     1) 编码问题

     2)认识文本和文本文件

     java的文本(char)是16位无符号整数,是字符的unicode编码(双字节编码)

     文件是byte byte byte ...的数据序列

    文本文件是文本(char)序列按照某种编码方案(utf-8,utf-16be,gbk)序列化为byte的存储结果

    3)字符流(Reader Writer)---->操作的是文本文本文件

    字符的处理,一次处理一个字符

    字符的底层任然是基本的字节序列

    字符流的基本实现

       InputStreamReader   完成byte流解析为char流,按照编码解析

       OutputStreamWriter  提供char流到byte流,按照编码处理  

       

       FileReader/FileWriter

     字符流的过滤器

       BufferedReader   ---->readLine 一次读一行

       BufferedWriter/PrintWriter   ---->写一行    

       

       

    3.对象的序列化,反序列化

    1)对象序列化,就是将Object转换成byte序列,反之叫对象的反序列化 

    2)序列化流(ObjectOutputStream),是过滤流----writeObject

       反序列化流(ObjectInputStream)---readObject


    3)序列化接口(Serializable)

       对象必须实现序列化接口 ,才能进行序列化,否则将出现异常

       这个接口,没有任何方法,只是一个标准

     

    4) transient关键字

        private void writeObject(java.io.ObjectOutputStream s)

            throws java.io.IOException

    private void readObject(java.io.ObjectInputStream s)

            throws java.io.IOException, ClassNotFoundException

       分析ArrayList源码中序列化和反序列化的问题

    5)序列化中 子类和父类构造函数的调用问题



  • 没看懂的可以来看一下

    <!--此处有图片-->




  • <!--此处有图片-->讲了一大堆

  • 本教程几点要点:

    RandomAccessFile类的使用,可以使用其中的指针自定义读取文件中的指定位置,实现分段读取,分段存储;

    java文件的保存方式是字节的形式保存的,byte,因此保存的文件有编码的问题;

    工程中读取或者保存在电脑中的文件会不会有乱码,与文件保存时的编码,以及工程编码属性这两个因素有关,需要注意这点;

    类的序列化:可重写writeObject、readObject两个方法来自定义类的序列化方法,将某些trasient的属性自定自定序列化。

首页上一页1234567下一页尾页

举报

0/150
提交
取消
课程须知
亲,为了更好的学习本门课程,需要您对二进制的知识有所了解,还要熟悉Java的基本语法和面向对象的知识。
老师告诉你能学到什么?
1、了解文件编码。 2、能够对文件和目录进行管理操作。 3、能够应用字节流和字符流对文件进行读写操作。 4、能够对对象进行序列化和反序列化。
意见反馈 帮助中心 APP下载
官方微信
友情提示:

您好,此课程属于迁移课程,您已购买该课程,无需重复购买,感谢您对慕课网的支持!