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

文件传输基础——Java IO流

难度入门
时长 2小时 0分
学习人数
综合评分9.67
669人评价 查看评价
9.9 内容实用
9.6 简洁易懂
9.5 逻辑清晰
  • File.list()方法用于列出当前目录下的子目录和文件,获取该目录下的所有文件 


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


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

    20140713155846393


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

    20140713155615781

    图转自博客:bingguang1993

    查看全部
    0 采集 收起 来源:遍历目录

    2020-01-31

  • 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类中简单的方法

    查看全部
  • 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项目下的文本文件中,他会自动进行转换

    查看全部
    0 采集 收起 来源:文件的编码

    2020-01-31

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

    查看全部
  • 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)序列化中 子类和父类构造函数的调用问题


    查看全部

  • 没看懂的可以来看一下

    http://img1.sycdn.imooc.com//5e207537000188e319201080.jpg

    查看全部



  • http://img1.sycdn.imooc.com//5e2073980001de7519201080.jpg讲了一大堆

    查看全部
    0 采集 收起 来源:遍历目录

    2020-01-16

  • java IO 1
    查看全部
    0 采集 收起 来源:文件的编码

    2019-12-20

  • 啦啦啦
    查看全部
    0 采集 收起 来源:遍历目录

    2019-12-12

  • 递归遍历目录

    查看全部
    0 采集 收起 来源:遍历目录

    2019-11-02

  • 文件输入流FileInputStream

    查看全部
  • 文件输出流FileOutputStream

    查看全部
  • 本教程几点要点:

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

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

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

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

    查看全部
    0 采集 收起 来源:文件的编码

    2019-10-31

举报

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

微信扫码,参与3人拼团

意见反馈 帮助中心 APP下载
官方微信
友情提示:

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