15:IO之File、Properties类
第一 File类
一、概述:File类是有文件或文件件封装而来的对象,可以操作其属性信息,这个类的出现弥补了流的不足,流只能操作数据
1、特点:
1)用来将文件或文件夹封装成对象
2)方便于对文件与文件夹的属性信息进行操作
3)File对象可以作为多数传递给流的构造函数
2、File类常见方法:
public class FileDemo {public static void main(String[] args) {// consMethod();// method();// listFilesDemo();// File dir = new File("E:\\develop\\eclipse space\\android workspace\\Test_java\\src");// showDir(dir);// method_1();// method_2(100);}/*** 构造方法演示*/public static void consMethod(){//创建file对象,可以将已有的和未出现的文件或目录封装成对象File f1 = new File("C:" + File.separator + "a.txt");//File.separator跨平台的目录分隔符File f2 = new File("c:\\abc","b.txt");//C:\\abc\\b.txt一样,但是两个参数更灵活,可以目录不变,文件变File d = new File("c:\\abc");File f3 = new File(d,"c.txt"); //这俩个和f2一样,不过f2目录是字符串对象,只能操作字符串方法System.out.println("f1: " + f1);System.out.println("f2: " + f2);System.out.println("f3: " + f3);}/*** 演示File类的一些常用方法*/public static void method_1(){File f = new File("file.txt");//exists()方法查看文件或目录是否存在System.out.println("exists:" + f.exists());//测试应用程序是否可以执行此抽象路径名表示的文件。System.out.println("canExecute:" + f.canExecute());//创建文件夹// File dir = new File("C:\\ab\\c\\v\\g");// System.out.println("mkdir:" + dir.mkdir());//最多只能创建两级目录,已经存在或失败返回false// System.out.println("mkdirs:" + dir.mkdirs());//创建多级目录File f1 = new File("c:\\ab\\d.java");try {f1.createNewFile();//createNewFile创建新文件} catch (IOException e) {e.printStackTrace();}//判断文件对象是否是文件或目录时,必须要先判断文件对象封装内容是否存在//通过exists方法System.out.println("isDir:" + f1.isDirectory());//是否是目录System.out.println("isFile:" + f1.isFile());//是否是文件//获取路径System.out.println("path: " + f1.getPath());System.out.println("abspath: " + f1.getAbsolutePath());System.out.println("parent: " + f1.getParent());//该方法返回的是绝对路径中的父目录。如果获取的是相对路径,返回null。//如果相对路径中有上一层目录那么该目录就是返回结果。//重命名,其实就是远文件再创建一个新文件,再把内容写入文件 (复制+重命名)File f2 = new File("c:\\ab\\d.java");File f3 = new File("d:\\d.java");System.out.println("rename:" + f2.renameTo(f3));}
- long len = file.length();
//文件的长度 - long time = file.lastModified();
//最后修改时间,可是时间是
- Date date = new Date(time);
//变成有效的格式时间 - DateFormat dateFormat = DateFormat.getDateTimeInstance(DateFormat.LONG,DateFormat.LONG);
- String str_time = dateFormat.format(date);

- System.out.println("len:"+len);
- System.out.println("time:"+time);
- System.out.println("str_time:"+str_time);
- public static void listRootsDemo() {
- File file = new File("d:\\");
- System.out.println("getFreeSpace:"+file.getFreeSpace());
可用空间 - System.out.println("getTotalSpace:"+file.getTotalSpace());
容量 - System.out.println("getUsableSpace:"+file.getUsableSpace());
可用空间,是给虚拟机用的
File[] files = File.listRoots();

for(File file : files){
//输出的是自己电脑上的各个盘的盘名
System.out.println(file);
public static void listDemo() {File file = new File("c:\\"); // a.txt错误String[] names = file.list();System.out.println(names.length);for (String name : names) {System.out.println(name);}}



public class FilterBytxt implements FilenameFilter(文件名过滤) { //过滤器,过滤txt文件public boolean accept(File dir, String name) {// System.out.println(dir+"---"+name);return name.endsWith(".txt");}}//可是每次过滤txt,过滤Java又得改。这个方法可以这样写public class SuffixFilter implements FilenameFilter {private String suffix ;public SuffixFilter(String suffix) { 传个什么过滤什么super();this.suffix = suffix;}@Overridepublic boolean accept(File dir, String name) {return name.endsWith(suffix);}}public static void listDemo_2() {File dir = new File("c:\\");String[] names = dir.list(new FilterBytxt );//(new SuffixFilter(".txt"));for(String name : names){System.out.println(name);}}
list是过滤文件名,不能过滤文件
public static void listFilesDemo(){File dir = new File("C:\\");File[] files = dir.listFiles();for(File f : files){System.out.println(f.getName() + "..." + f.length());}}}
String[] names = file.list();System.out.println(names.length);for(String name : names){System.out.println(name);
public class FilterByHidden implements FileFilter(文件过滤) { //过滤器,过滤隐藏文件,用 listFiles@Overridepublic boolean accept(File pathname) {return !pathname.isHidden(); //不要隐藏为真}}public static void listDemo_3() {File dir = new File("c:\\");File[] files = dir.listFiles(new FilterByHidden());for(File file : files){System.out.println(file);}}

files[x]传进 listAll就可以了,就可以列出这个目录的内容


- public static void method(){
File dir = new File("C:\\");String[] names = dir.list(new FilenameFilter() {@Overridepublic boolean accept(File dir, String name) {// System.out.println("dir:" + dir + ".....name::" + name);return name.endsWith(".txt");}});System.out.println("list.len:::" + names.length);for(String name : names){System.out.println(name);}}
注意:
1、限定条件,是作为结束循环用的,否则是死循环
public static void show(){
method();
}
public static void method(){
show();
}
2、注意递归的次数,尽量避免内存溢出。因为每次调用自身的时候都会先执行下一次调用自己的方法那个方法,所以会不断在栈内存中开辟新空间,次数过多,会导致内存溢出。
实例一:求和和求二进制
- * 递归方法演示
public static int method_2(int num){// //求和// if(num == 1){// return 1;// }// return num + method_2(num - 1);//求二进制StringBuilder sb = new StringBuilder();if(num > 0){method_2(num/2);int i = num%2;sb.append(i);}System.out.println(sb.toString());return -1;}


思路:既然要显示所有文件,就是要循环每一个文件夹,找出所有文件,这里操作文件夹的动作都是一样的,所有需要用到递归:
- * 显示所有目录下的文件,也就是说只要是目录就被循环
public static void showDir(File dir){System.out.println(dir);File[] files = dir.listFiles();for(File f : files){if(f.isDirectory()){showDir(f);}else{System.out.println(f);}}}
public class RemoveDirTest {public static void main(String[] args) {File dir = new File("e:\\demodir");// dir.delete();removeDir(dir);}public static void removeDir(File dir) {File[] files = dir.listFiles();for (File file : files) {if (file.isDirectory()) {removeDir(file);} else {System.out.println(file + ":" + file.delete());}}System.out.println(dir + ":" + dir.delete());}}
public class Test {public static void main(String[] args) throws IOException {File dir = new File("e:\\java0331");FilenameFilter filter = new FilenameFilter() {// 过滤器,匿名内部类public boolean accept(File dir, String name) {return name.endsWith(".java");}};List<File> list = new ArrayList<File>();getFiles(dir, filter, list);File destFile = new File(dir, "javalist.txt");// 目的文件,当前文件write2File(list, destFile);}/*** 对指定目录中的内容进行深度遍历,并按照指定过滤器,进行过滤, 将过滤后的内容存储到指定容器List中。 File* dir,FilenameFilter filter,List<File> list一个目录,文件名过滤,存储的容器*/public static void getFiles(File dir, FilenameFilter filter, List<File> list) {File[] files = dir.listFiles();// 深度遍历for (File file : files) {if (file.isDirectory()) {// 递归getFiles(file, filter, list);} else {// 对遍历到的文件进行过滤器的过滤。将符合条件File对象,存储到List集合中。if (filter.accept(dir, file.getName())) {list.add(file);}}}}// 将集合写到文件去public static void write2File(List<File> list, File destFile)throws IOException {BufferedWriter bufw = null;try {bufw = new BufferedWriter(new FileWriter(destFile));for (File file : list) {bufw.write(file.getAbsolutePath());bufw.newLine();bufw.flush();}} /** catch(IOException e){//可以写可以不写** throw new RuntimeException("写入失败"); }*/finally {if (bufw != null)try {bufw.close();} catch (IOException e) {throw new RuntimeException("关闭失败");}}}}
思路:
1、对指定目录进行递归
2、获取递归过程中所有的java文件
3、把路径存放在集合中
4、把集合中的数据写入文件
* 将一个指定目录下的java文件的绝对路径,存储到一个文本文件中。** 思路:* 1、对指定目录进行递归* 2、获取递归过程中所有的java文件* 3、把路径存放在集合中* 4、把集合中的数据写入文件*/public class JavaFileList {public static void main(String[] args) {// 指定查找路径File dir = new File("E:\\develop\\eclipse space\\android workspace\\Test_java");// 定义集合用于存储取到的java路径List<File> list = new ArrayList<File>();fileToList(dir, list);// 调用查找文件方法// System.out.println(list.size());// 指定写入文件路径File file = new File("c:\\", "javalist.txt");writeToFile(list, file.toString());// 调用写入文件的方法}/** 获取指定目录下的java文件*/public static void fileToList(File dir, List<File> list) {File[] files = dir.listFiles();// 返回该目录下的文件对象for (File f : files) {if (f.isDirectory()) {fileToList(f, list);} else {if (f.getName().endsWith(".java"));// 找出java文件list.add(f);}}}/** 将数据写入文件中*/public static void writeToFile(List<File> list, String filepath) {BufferedWriter bfw = null;try {bfw = new BufferedWriter(new FileWriter(filepath));for (File f : list) {String path = f.getAbsolutePath();// 获取文件绝对路径bfw.write(path);bfw.newLine();bfw.flush();}} catch (IOException e) {e.printStackTrace();} finally {if (bfw != null) {try {bfw.close();} catch (IOException e) {e.printStackTrace();}}}}}
第二 Properties类
一、概述:
1、Properties是Hashtable的子类,也就是map集合的子类,所有具备Map集合的特点,而且它里面还有存储的键值对,都是字符串,无泛型定义。是集合中和IO技术相结合的集合容器。
2、特点:
1)可用于键值对形式的配置文件
2)在加载时,需要数据有固定的格式,常用的是:键=值
二、特有方法:
1、设置和获取元素:
Object setProperty(String key,String value)调用Hashtable 的方法put,将键和值存入到properties对象中
String getProperty(String key)用指定的键在此属性列表中搜索属性
Set<String> stringPropertyName()返回此属性列表中的键集
void load(InputStream ism)从输入流中读取属性列表(键和元素对)。
void load(Reader reader)按简单的面向行的格式从输入字符流中读取属性列表(键和元素对)。
实例:
- public class ProPertiesDemo {
public static void main(String[] args) {getAndSet();// method();loadDemo();}/** 设置和获取元素。*/
public static void getAndSet(){Properties pro = new Properties();pro.setProperty("zhangsan", "20");pro.setProperty("lisi", "30");System.out.println(pro); //{zhangsan=20, lisi=12}String value = pro.getProperty("lisi");System.out.println("getProperty: " + value); //获取pro.setProperty("lisi", "90"); //修改Set<String> names = pro.stringPropertyNames(); //取出所有键和值for(String name : names){//String value = pro.getProperty(name );System.out.println(name + "::" + pro.getProperty(name));//System.out.println(name + "::" + value);}}

public static void methodDemo_2(){Properties prop = new Properties();//存储元素。prop.setProperty("zhangsan","30");prop.setProperty("lisi","31");///prop = System.getProperties(); 打印出所有配置信息prop.list(System.out); //键和值全部打印出,但是不能操作,zhangsan=20,lisi=12}//store方法,将集合中数据存储到文件中public static void methodDemo_3() throws IOException {Properties prop = new Properties();//存储元素。prop.setProperty("zhangsan","30");prop.setProperty("lisi","31");//想要将这些集合中的字符串键值信息持久化存储到文件中。//需要关联输出流。FileOutputStream fos = new FileOutputStream("info.txt");//将集合中数据存储到文件中,使用store方法。prop.store(fos, "info");//"info"键值信息,不要写中文,Java中配置信息文件的后缀名是 properties,window是inifos.close();}
public static void methodDemo_4() throws IOException {Properties prop = new Properties();FileInputStream fis = new FileInputStream("info.txt");//使用load方法。prop.load(fis);prop.list(System.out); //调试,验证}
模拟load方法
/** 演示如何将流中的数据存储到集合中* 想要将info.txt中的数据存放在集合中进行操作** 思路:* 1、用流关联info.txt文件* 2、读取一行数据,将改行数据用“=”切割* 3、将等号左边作为键,右边作为值存放到properties集合中*/public static void method(){BufferedReader bfr = null;Properties pro = null;try {bfr = new BufferedReader(new FileReader("info.txt"));pro = new Properties();String line = null;while((line=bfr.readLine()) != null){if(line.startsWith("#")) //#号开头的不切continue;String[] arr = line.split("=");pro.setProperty(arr[0], arr[1]); //设置键值}} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}finally{if(bfr != null){try {bfr.close();System.out.println(pro);} catch (IOException e) {e.printStackTrace();}}}}//对已有的配置文件中的信息进行修改。/** 读取这个文件。* 并将这个文件中的键值数据存储到集合中。* 在通过集合对数据进行修改。* 在通过流将修改后的数据存储到文件中。public static void test() throws IOException{//要判断这个文件是否存在需要,把这个文件封装成对象进行操作File file = new File("info.txt");if(!file.exists()){file.createNewFile();}//读取这个文件。FileReader fr = new FileReader(file);//创建集合存储配置信息。Properties prop = new Properties();//将流中信息存储到集合中。prop.load(fr);prop.setProperty("wangwu", "16");//这里修改只是在内存中,而没有修改文件FileWriter fw = new FileWriter(file); //不能写到上边去,这个一创建就把原来的覆盖了prop.store(fw," "); //不写注释了,当然也可以写// prop.list(System.out);fw.close();fr.close();}
- /*
- 思路:
- * 1,应该有计数器。
- * 每次程序启动都需要计数一次,并且是在原有的次数上进行计数。
- * 2,计数器就是一个变量。 程序启动时候进行计数,计数器必须存在于内存并进行运算。
- * 可是程序一结束,计数器消失了。那么再次启动该程序,计数器又重新被初始化了。
- * 而我们需要多次启动同一个应用程序,使用的是同一个计数器。
- * 这就需要计数器的生命周期变长,从内存存储到硬盘文件中。
- *
- * 3,如何使用这个计数器呢?
- * 首先,程序启动时,应该先读取这个用于记录计数器信息的配置文件。
- * 获取上一次计数器次数。 并进行试用次数的判断。
- * 其次,对该次数进行自增,并自增后的次数重新存储到配置文件中。
- *
- *
- * 4,文件中的信息该如何进行存储并体现。
- * 直接存储次数值可以,但是不明确该数据的含义。 所以起名字就变得很重要。
- * 这就有了名字和值的对应,所以可以使用键值对。
- * 可是映射关系map集合搞定,又需要读取硬盘上的数据,所以map+io = Properties.
- *
- * 配置文件可以实现应用程序数据的共享。
public class PropertiesTest {public static void main(String[] args) throws IOException {getAppCount();}public static void getAppCount() throws IOException {// 将配置文件封装成File对象。File confile = new File("count.properties"); // 新建的配置if (!confile.exists()) {confile.createNewFile();}FileInputStream fis = new FileInputStream(confile); // confile是个文件Properties prop = new Properties();prop.load(fis); // 将文件的数据存储在集合中// 从集合中通过键获取次数(time是键)。String value = prop.getProperty("time");// 定义计数器。记录获取到的次数。不能直接time++,因为第一次运行时没有配置信息文件,新建了一个,但是没有数据,拿不到// 值,返回nullint count = 0;if (value != null) {count = Integer.parseInt(value);// 次数是字符串,需要转换if (count >= 5) {// System.out.println("使用次数已到,请注册,给钱!");// return;throw new RuntimeException("使用次数已到,请注册,给钱!");}}count++;// 将改变后的次数重新存储到集合中。prop.setProperty("time", count + ""); // 名字:次数(转成字符串)FileOutputStream fos = new FileOutputStream(confile);prop.store(fos, "");fos.close();fis.close();}}
15:IO之File、Properties类的更多相关文章
- IO流之Properties类
Properties类介绍 Properties 类表示了一个持久的属性集.Properties 可保存在流中或从流中加载.属性列表中每个键及其对应值都是一个字符串. 特点: 1.Hashtable的 ...
- Java笔记(二十七)……IO流中 File文件对象与Properties类
File类 用来将文件或目录封装成对象 方便对文件或目录信息进行处理 File对象可以作为参数传递给流进行操作 File类常用方法 创建 booleancreateNewFile():创建新文件,如果 ...
- Java IO流中 File文件对象与Properties类(四)
File类 用来将文件或目录封装成对象 方便对文件或目录信息进行处理 File对象可以作为参数传递给流进行操作 File类常用方法 创建 booleancreateNewFile():创建新文件,如果 ...
- Java基础---IO(二)--File类、Properties类、打印流、序列流(合并流)
第一讲 File类 一.概述 1.File类:文件和目录路径名的抽象表现形式 2.特点: 1)用来将文件或文件夹封装成对象 2)方便于对文件与文件夹的属性信息进行操作 3)File类的实例是不 ...
- Java学习笔记31(IO:Properties类)
Properties类,表示一个持久的j集,可以存在流中,或者从流中加载 是Hashtable的子类 map集合的方法都能用 用途之一:在开发项目中,我们最后交给客户的是一个编译过的class文件,客 ...
- IO概述、异常、File文件类_DAY19
IO概述: 操作数据的工具 IO流,即数据流,数据像水流一样通过IO工具进行传输. 程序 <IO> 硬盘 绝对路径与相对路径 1:异常(理解) (1)就是程序的非正常情况. 异常相关 ...
- Java—IO流 File类的常用API
File类 1.只用于表示文件(目录)的信息(名称.大小等),不能用于文件内容的访问. package cn.test; import java.io.File; import java.io.IOE ...
- java io包File类
1.java io包File类, Java.io.File(File用于管理文件或目录: 所属套件:java.io)1)File对象,你只需在代码层次创建File对象,而不必关心计算机上真正是否存在对 ...
- IO—》Properties类&序列化流与反序列化流
Properties类 介绍:Properties 类表示了一个持久的属性集.Properties 可保存在流中或从流中加载.属性列表中每个键及其对应值都是一个字符串. Properties类特点: ...
随机推荐
- TCP与UDP,可靠UDP如何实现
两种协议都是传输层协议,为应用层提供信息载体. TCP协议是基于连接的字节流的可靠协议,有三次握手,四次挥手,超时重传,流量控制(滑动窗口),拥塞控制和差错控制,也正因为有可靠性的保证和控制手段,所以 ...
- 最小费用最大流 HDU1533
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1533 #include<bits/stdc++.h> #define fi first ...
- python学习笔记(七)- 递归、python内置函数、random模块
1.函数的不固定参数: #参数不是必填的.没有限制参数的个数.返回参数组的元组 def syz(*args): #参数组,不限制参数个数 #‘args’参数的名字可以随便命名 print(args) ...
- IP路由配置之---------dhcp服务器配置
实验设备:一台华三路由器,一台PC 步骤一,在系统视图下打开dhcp功能,禁用IP(网关,域名服务器) [H3C]dhcp enable # [H3C]dhcp server forbidden-ip ...
- c++ 面试题(操作系统篇)
1,消息队列: https://kb.cnblogs.com/page/537914/ 2,fork中父进程和子进程的资源联系: https://blog.csdn.net/weixin_422506 ...
- TZOJ 5101 A Game(区间DP)
描述 Consider the following two-player game played with a sequence of N positive integers (2 <= N & ...
- Android抓取log日志过滤
前提:Android SDK已安装并配置环境变量 1.手机USB调试模式打开,连接PC 2.cmd窗口,执行adb logcat >log.log // 输出日志到一个log文件 或者执行a ...
- PHP开发——环境安装
PHP环境 Apache IDE的选择
- Piwis Tester II V18.100 with CF30 Laptop for Porsche
Porsche Piwis Tester II is the latest professional tester for Porshe,the most poweful diagnose and o ...
- 如何解决PHP的高并发和大流量的问题
基础知识 TFS : 吞吐量 (吞吐量是指系统在单位时间内处理请求的数量) RT : 响应时间 (从请求发出到收到响应时间) 并发数 : 在一段时间内同时访问站点的用户数 QPS : 每秒查询率 (每 ...