一、IO概述:

把内存中的数据存入到硬盘(持久化设备)中叫做:输出(写)Output操作。JAVA软件往电脑硬盘上走叫输出。

把硬盘中的数据读取到到内存里叫做:输入(读)Input操作。电脑硬盘上往JAVA软件里走叫输入。

以JAVA软件为参照物。

这种输入输出的动作叫做IO操作。

二、File类(文件类)

2.1定义:File是文件和目录(文件夹)路径名的抽象表现形式,即:JAVA把文件和目录都封装为File对象

2.2构造函数:

       //File构造方法无法判定你写的这个文件是否真的存在
//第一种方法,直接填写路径
File f=new File("e:\\java\\dandan.java");//写路径时写两道杠,用来转译'\' 符号
System.out.println(f);
//第二种方法,将路径跟文件名分开写作字符串,比较灵活
String parent="e:\\java";
String child="dandan.java";
File f2=new File(parent,child);
System.out.println(f2);
//第三种方法,将父类的路径变为文件对象,子类还是字符串 最为灵活
File p=new File("d:\\java");
String c="b.java";
File f3=new File(p,c);
System.out.println(f3);

 2.3File类相关信息的获取方法:

            //绝对路径
File f=new File("e:\\study\\codetool\\jdk\\src.zip");
//获取文件或文件夹的名称
System.out.println(f.getName());
//getPath相当于toString方法得到的值
System.out.println(f.getPath());
//得到文件的字节数(Long类型的值)
System.out.println(f.length());
//获得绝对路径:getAbsolutePath()
//当你写相对路径的时候,会获得工程根路径+相对路径 但是不会判断是否正确
File f=new File("src");
System.out.println(f.getAbsolutePath());

2.4 文件和文件夹的创建删除方法:

                //创建文件   createNewFile()
File f=new File("e:\\java\\xxx.java");
f.createNewFile();
//创建文件夹 mkdir
File f=new File("e:\\java\\aaa\\bbb\\ccc");
//f.mkdir();
//创建多级文件夹 .mkdirs() 尽量用这个方法,比上面只能创建一个的好用
f.mkdirs();
//删除文件夹
File f=new File("e:\\java\\新建文件夹");
//多重路径下的需要先删底层的,一步步删上来
//f.delete();
//注意:delete() 方法删除的文件或文件夹是不走回收站的,直接从硬盘删除
//删除需谨慎,一般不用这个方法,因为找不回来
//.exists() 可以验证路径及文件是否存在,并返回一个true或false
File f=new File("e:\\java\\nishizhuma.txt");
System.out.println(f.exists());
// .isDirectory() 判断文件对象是否是文件夹
System.out.println(f.isDirectory());
//.isFile() 判断文件对象是否是文件
System.out.println(f.isFile());

2.5 listFiles()方法:

用来获取一个目录中所有的文件或文件夹。

        File f=new File("e:\\java");
//获取该路径下的所有文件和文件夹的字符串
String[] filearr=f.list();
for(String s:filearr){
System.out.println(s); //打印的是文件名
}
//将所有文件存入一个数组中
File[] file=f.listFiles();
for(File f1:file){
System.out.println(f1); //打印的是路径+文件名
}

注意:在获取指定目录下的文件或者文件夹时必须满足下面两个条件

1,指定的目录必须是存在的,

2,指定的必须是目录。否则容易引发返回数组为null,出现NullPointerException

 2.6 文件过滤器:

File类中重载的listFiles方法,并且接受指定的过滤器。

  过滤器的使用:

public static void main(String[] args) {
File f=new File("e:\\java");
getFile(f); }
public static void getFile(File f){
//通过文件过滤器,将返回为true的文件存入数组中
File[] file=f.listFiles(new MyFilter()); //new MyFilter() 文件过滤器
for(File f1:file){
System.out.println(f1);
}
}

自定义一个过滤器类:只打印名称以.java结尾的文件

package com.oracle.Demo01;

import java.io.File;
import java.io.FileFilter; public class MyFileter implements FileFilter { @Override
public boolean accept(File pathname) {
if(pathname.isDirectory()){
return true;
}
//将文件名称全部转小写 因为在windows系统中,文件名称是不区分大小写,但是在java文件中是区分的,所以需要先转换为小写
return pathname.getName().toLowerCase().endsWith(".java");
} }

Java第三阶段学习(一、IO流------File类)的更多相关文章

  1. Java—IO流 File类的常用API

    File类 1.只用于表示文件(目录)的信息(名称.大小等),不能用于文件内容的访问. package cn.test; import java.io.File; import java.io.IOE ...

  2. 09、IO流—File类与IO流

    目录 一.File类 基本认识 实用方法 获取功能 重命名功能(包含剪切) 判断功能 创建.删除文件 实际小案例 二.IO流 1.认识IO流 2.IO流基类介绍 字节流基类介绍 字符流基类介绍 三.节 ...

  3. Java第三阶段学习(二、IO流--------递归,字节流Stream)

    一.递归 定义:指方法在方法内调用自己 适用于方法的运算主体不变,但运行的时候,参与运算的方法参数会变化注意:一定要给递归一个出口,否则内存溢出 练习题1:使用递归打印文件夹中所有的文件,包含子目录中 ...

  4. Java第三阶段学习(五、流的操作规律、Properties流、序列化流与反序列化流、打印流、commons-IO jar包)

    一.流的操作规律 四个明确: 明确一:明确要操作的数据是数据源还是数据目的地 源:InputStream   Reader 目的地:OutputStream Writer 先根据需求明确是要读还是写 ...

  5. Java第三阶段学习(四、缓冲流)

    一.缓冲流: Java中提供了一套缓冲流,它的存在,可提高IO流的读写速度 缓冲流,根据流的分类分为:字节缓冲流与字符缓冲流. 二.字节缓冲流: 字节缓冲流根据流的方向,共有2个: 1.写入数据到流中 ...

  6. Java第三阶段学习(八:网络通信协议、UDP与TCP协议)

    一.网络通信协议 1.概念: 通过计算机网络可以使多台计算机实现连接,位于同一个网络中的计算机在进行连接和通信时需要遵守一定的规则,在计算机网络中,这些连接和通信的规则被称为网络通信协议,它对数据的传 ...

  7. Java第三阶段学习(六、多线程)

    一.进程和线程的区别: 进程:指正在运行的程序,当一个程序进入内存运行,就变成一个进程. 线程:线程是进程的一个执行单元. 总结:一个程序运行后至少会有一个进程,一个进程可以有多个线程. 多线程:多线 ...

  8. JAVA:IO流——File类

    1.掌握File 类的作用 2.可以使用File 类中的方法对文件进行操作 所有的 io 操作都保存在 java.io 包中. 构造方法:public File (String pathname) 直 ...

  9. Java学习之IO之File类一

    File的操作 package com.gh.file; import java.io.File; import java.io.IOException; /** * File操作 * @author ...

随机推荐

  1. Linux运维三:系统目录结构

    Linux系统目录结构官方参考:http://www.pathname.com/fhs/ 1:Linux树状目录结构图 下面目录中标红的是必须要掌握的! 2:根目录  目录 描述 / 第一层次结构的根 ...

  2. CoreDNS配置kubernetes作为后端

    概述 coredns之所以如此名声大噪,就是因为从kubernetes1.9开始引入,作为kubernetes内部服务发现的默认dns.毫无疑问kubernetes是coredns的后端之一,所以我们 ...

  3. pyqt4_应用例子(计算器,对话框,进度条,日历等等)

    sklearn实战-乳腺癌细胞数据挖掘(博客主亲自录制视频教程) https://study.163.com/course/introduction.htm?courseId=1005269003&a ...

  4. Hadoop生态圈-Hive函数

    Hadoop生态圈-Hive函数 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.

  5. RabbitMQ基础介绍

    非原创,仅作为个人的学习资料,转自 anzhsoft http://blog.csdn.net/anzhsoft/article/details/19563091, 1. 历史 RabbitMQ是一个 ...

  6. 科学计算三维可视化---TVTK管线与数据加载(可视化管线和图像管线了解)

    一:TVTK的管线 使用管线技术将TVTK中各个对象穿连起来,几乎所有渲染引擎都会提到管线技术 在TVTK中,每个对象只需要实现相对简单的任务,整个管线则能根据用户的需求,实现复杂的数据可视化处理. ...

  7. mongodb 跟踪SQL语句及慢查询收集

    有个需求:跟踪mongodb的SQL语句及慢查询收集 第一步:通过mongodb自带函数可以查看在一段时间内DML语句的运行次数. 在bin目录下面运行  ./mongostat -port 端口号  ...

  8. 图论:LCA-欧拉序

    #include<cmath> #include<vector> #include<cstdio> #include<cstring> #include ...

  9. Java并发编程原理与实战二十四:简易数据库连接池

    public class MyDataSource { private static LinkedList<Connection> pool = new LinkedList<> ...

  10. bootstrap-tooltip+validate

    名称 返回类型 描述 validate(options) 返回:Validator 验证所选的FORM valid() 返回:Boolean 检查是否验证通过 rules() 返回:Options 返 ...