File 类

  • File类是java.io包中很重要的一个类

  • File类的对象可以表示文件,还可以表示目录,在程序中的一个File类对象可以代表一个文件或目录

  • File对象可以对文件或目录的属性进行操作,如:文件名,最后修改日期,文件大小等

  • File对象无法操作文件的具体数据,即不能对文件进行读或写的操作

File 构造方法

方 法 原 型 说明
File (String pathname) 指定文件(或目录)名和路径创建文件对象
//在当前目录先创建一个与aaa.txt文件名相关联的文件对象
File f1 = new File("aaa.txt");
//指明详细的路径以及文件名,请注意双斜线或用反斜杠
File f2 = new File("D:\\Java\\Hello.java");
//指明详细的路径以及目录名,请注意双斜线
File f3 = new File("D\\Java");
方法原型 说明
boolean exists() 判断文件是否存在 存在-true 不存在-false
boolean isFile() 判断是否为文件,是-true 不是-false
boolean isDirectory() 判断是否为目录,是目录-true 不是-false
String getName() 获取文件名称
long length() 获取文件长度(字节数)
boolean creatNewFile()throws IOException 创建新文件,成功-true 失败false,有可能抛出IOException异常,必须捕捉
boolean delete() 删除文件,成功-true 失败-false
public String[] list() 将目录下的子目录以及文件的名字,返回到String数组
public Flie[] listFiles() 将目录下的子目录以及文件的实例返回到File数组

输入输出(I/O)

  • 输入输出(I/O)把电脑硬盘的数据读到程序中,称为输入,即input,进行数据的read操作从程序往外部设备写数据,称为输出,即output,进行数据的write操作

体系图

字节流与字符流

  • 从数据流编码格式上划分为

    • 字符流
    • 字节流

输入流与输出流

  • 流按着数据的传输方向分为:

    • 输入流: 往程序中读叫输入流
    • 字节流:从程序中往外写叫输出流
    • InputStreamOutputStream的子类都是字节流,可以读写二进制文件,主要处理音频图片,歌曲,字节流,处理单元为 一个字节
    • ReaderWriter的子类都是字符流 主要处理字符或字符串,字符流处理的单元为 一个字符. 字节流将读取到的字节数据,去指定的编码表中获取对应文字字符
  • 字节流中常用的类

    • 字节输入流 FIleInputStream
    • 字节输出流FileOutputStream
  • 字符流的常用类

    • 字符输入流 FileReader
    • 字符输出流FileWriter

输入输出字节流

构造方法

FileInputStream in =new FileInputStream("D:\\777\\新建 文本文档.txt");//括号里面也可以是File对象
FileOutputStream out = new FileOutputStream("D:\\aaaa.c");////括号里面也可以是File对象

方法

InputStream 基本方法

public int read() throws IOException

  • 读取一个字节并以整数的形式返回(0~255),如果返回-1,已到输入流的末尾

public int read(byte[] buffer) throws IOException

  • 读取一系列字节并存储到一个数组buffer,返回实际读取的字节数,如果读取前已到输入流的末尾,返回-1

public void close() throws IOException

  • 关闭流,释放内存资源

OutputStream 基本方法

public void write(int b) throws IOException

  • 向输出写入一个字节数据,该字节数据位参数b的低8位

public void write(byte[] b,int off,int len) throws IOException

  • 将一个字节类型数组中的从指定位置(off)开始到len个字节写入输出流

public void close() throws IOException

  • 关闭流释放内存资源

实际使用

public class StreamDemo {
public static void main(String[] args) throws IOException {
FileInputStream in =new FileInputStream("D:\\777\\新建 文本文档.txt");
FileOutputStream out = new FileOutputStream("D:\\aaaa.c");
// System.out.println(in.read()); //每read一次返回一个字节编码 读完返回-1
//
// System.out.println(in.read());
/*
int read() 默认一次读一个字节,返回的是读到的字节编码 返回效率低
int read(byte[] b) 默认一次读一个指定大小的byte个字节 返回的数组中一次实际
装入的字节个数
*/
int t;
while((t=in.read())!=-1){
out.write(t);
}
int size;
byte[] b = new byte[10000];
while((size=in.read(b))!=-1){
out.write(b,0,size);//从0开始读,读到文件字节长度,比直接write(b)节省空间 }
//关闭流对文件的占用
in.close();
out.close();
}
}
  • DataOutputStreamDataInputStream 也属于输入输出字节流,与FIleOutputStream,FileInputStream区别:前者的输入输出是以原始数据类型为基本单位输入输出(char ,int ),后者则是以 字节 为单位进行读写

  • DataOutputStreamDataInputStream底层还是对字节的处理

输入输出字符流(Reader Writer)

构造方法

File file =new File("D:/777/888/999/新建 文本文档.txt");
Reader read = new FileReader(file);
//....还有其他多种构造对象方法
 Writer writer = new FileWriter(file);

方法

方法与上面方法名与用法一样,区别:Reader与Writer只能处理纯字符的文件!!!!

Print流

  • Print 打印流

    • 只做输出没有输入 打印流分为字节打印流和字符打印流
    • PrintWrite
      • 字符打印流 print 方法可以打印各种类型数据
      • 在javaweb 项目中,服务器端相应数据以打印流的方式响应

对象输入输出流--对象序列化

序言:对象的寿命通常随着生成该对象的程序终止而终止,有时候,可能需要将对象的状态保存下来,在需要时候再将对象恢复

对象的序列化可以形象地比喻为将一个对象从内存中“拍成照片”,并将其存储在可以持久化的存储设备(如磁盘)上。当需要还原这些数据时,可以通过反序列化的过程,将这些照片重新“冲洗”出来,并还原成原始对象

  • 对象的输入输出流
  • 主要作用:用于写入对象信息与读取对象信息,对象信息一旦写到文件上那么对象的信息就可以做到持久化
    • 对象输出流ObjectOutputStream
    • 对象输入流ObjectInputStream
    • 当然也有对应的读写方法
      • readObject()方法读取一个对象
      • writeObject方法将对象保存到输出流
  • 对象的输出流将制定的对象写入到文件的过程中,就是将对象序列化的过程
  • 对象的输入流将指定序列化好的文件读出来的过程,就是将对象反序列化
  • 对象的输出流将对象写入到文件中称为对象的序列化, 所以被序列化的对象必须要实现 Serializable接口,Serializable接口中没有任何方法.  当一个类声明实现Serializable接口后,表明该类可被序列化

private static final long serialVersionUID = -5974713180104013488L

  • 随机生成 唯一的 serialVersionUID用来表明实现序列化类的不同版本间的兼容性. 某个类在与之对应的对象已经序列化出去后做了修改,该对象依然可以被正确的反序列化
  • 如果不显示生成序列号,那么将会隐式生产,但隐式生成后,类一旦发生改变,序列号也会随之变化

transient 关键字

  • 默认情况下当执行了对象序列化的时候会将类中的全部属性的内容进行全部的序列化操作但是很多情况下有一些属性并不需要序列化处理,这个时候就可以在属性的定义上使用transient关键字;来完成了
  • private transient String name;

idea中设置 ,在类中生成序列化id

Java中File类和I/O的更多相关文章

  1. java中File类的常用方法总结

    java中File类的常用方法 创建: createNewFile()在指定的路径创建一个空文件,成功返回true,如果已经存在就不创建,然后返回false. mkdir() 在指定的位置创建一个此抽 ...

  2. Java 中File类的createNewFile()与createTempFile(), delete和deleteOnExit区别

    1. Java 中File类的createNewFile()与createTempFile()的区别 最近,在看代码时看到了一个方法, File.createTempFile() ,由此联想到File ...

  3. Java中File类的基本用法

    File类的基本用法 java.io.File类:代表文件和目录.在开发中,读取文件.生成文件.删除文件.修改文件的属性时经常会用到此类. File类的常用构造方法:public File(Strin ...

  4. java中File类的使用

    public class FileLei {    public static void main(String[] args) throws IOException {        //..表示上 ...

  5. java中File类的相关学习

    File类 1.关于系统路径分割符. 在Windows中,使用反斜杠“\”作为路径分割符,比如“c:\test”,但是java中反斜杠表示转义,所以需要用“C:\\test”在程序中来表示路径.还可以 ...

  6. java中File类的常用所有方法及其应用

    创建:createNewFile()在指定位置创建一个空文件,成功就返回true,如果已存在就不创建,然后返回false.mkdir()  在指定位置创建一个单级文件夹.mkdirs()  在指定位置 ...

  7. java中File类中list()和listFiles()方法区别

    list()和listFiles()方法区别: 1.返回值类型不同:前者为String数组,后者为File对象数组 2.数组中元素内容不同:前者为string类型的[文件名](包含后缀名),后者为Fi ...

  8. Java中File类总结

    /** * @Title:JavaFile.java * @Package:com.yhd.chart.model * @Description:File类测试 * @author:Youhaidon ...

  9. Java中File类的方法详解

    File类也是Java中一个比较重要的类,通过他我们可以实现对文件的一系列操作,其内置了很多方法,下面我将按方法的功能分块,逐一讲解: 快速导航 构造方法 常用方法 创建目录 判断 `is...` t ...

  10. Java中File类

    File类是java.io包中唯一代表磁盘文件本身的对象.File类的对象主要用来获取文件本身的一些信息,如文件所在目录.文件长度.读写权限等. 一. 文件的创建与删除 通常使用以下三种方法来创建一个 ...

随机推荐

  1. 【vue】纯前端图形验证码实现

    [vue]纯前端图形验证码实现 感觉人不能在SQL里面淹死,得看看别的东西了 因为是上班摸鱼偷摸搞的,所以人比较懒,很多东西也懒得修修改改,直接放在一个html文件下了 页面如下 js的生成图形逻辑是 ...

  2. 力扣378(java&python)-有序矩阵中第 K 小的元素(中等)

    题目: 给你一个 n x n 矩阵 matrix ,其中每行和每列元素均按升序排序,找到矩阵中第 k 小的元素.请注意,它是 排序后 的第 k 小元素,而不是第 k 个 不同 的元素. 你必须找到一个 ...

  3. 力扣342(java)-4的幂(简单)

    题目: 给定一个整数,写一个函数来判断它是否是 4 的幂次方.如果是,返回 true :否则,返回 false . 整数 n 是 4 的幂次方需满足:存在整数 x 使得 n == 4x 示例 1: 输 ...

  4. 聊聊日志硬扫描,阿里 Log Scan 的设计与实践

    简介: SLS 新推出 Scan 功能,让未索引的字段也支持搜索(硬扫描模式),节省全量索引产生的构建和存储费用,同时 Scan 的运行时计算模式对于杂乱结构的日志数据有更好的适配,帮助企业客户实现数 ...

  5. KubeVela v1.3 多集群初体验,轻松管理应用分发和差异化配置

    ​简介:KubeVela v1.3 在之前的多集群功能上进行了迭代,本文将为你揭示,如何使用 KubeVela 进行多集群应用的部署与管理,实现以上的业务需求. 作者:段威(段少) 在当今的多集群业务 ...

  6. 大型 Web 应用插件化架构探索

    简介: 随着 Web 技术的逐渐成熟,越来越多的应用架构趋向于复杂,例如阿里云等巨型控制台项目,每个产品下都有各自的团队来负责维护和迭代.不论是维护还是发布以及管控成本都随着业务体量的增长而逐渐不可控 ...

  7. 深度 | 从DevOps到BizDevOps, 研发效能提升的系统方法

    ​简介:研发效能提升不知从何下手.一头雾水?阿里资深技术专家一文为你揭秘研发效能提升的系统方法. ​ 注:本文是对云栖大会何勉分享内容的整理 这几年"研发效能"一直是热词,很多组织 ...

  8. 【产品动态】解读Dataphin流批一体的实时研发

    ​简介: Dataphin作为一款企业级智能数据构建与管理产品,具备全链路实时研发能力,从2019年开始就支撑可集团天猫双11的实时计算需求,文章将详细介绍Dataphin实时计算的能力. 背景 每当 ...

  9. [Pholcus] Go项目 Pholcus 源码逻辑分析 species.go

    「代码结构」 结构体:蜘蛛种类列表(即:蜘蛛规则列表) 变量:全局蜘蛛种类实例 方法:向蜘蛛种类清单添加新种类 方法:获取全部蜘蛛种类 方法:通过名字获取蜘蛛 「总体功能」 添加新种类:通过 Spid ...

  10. [FE] Quasar 性能优化: 减小 vendor.js 尺寸

    默认情况下,出于性能和缓存的原因,Quasar 所有来自 node_modules 的东西都会被注入到 vendor 中. 但是,如果希望从这个 vendor.js 中添加或删除某些内容,可以如下这样 ...