java学习日志---File实例:实现复制整个文件夹、解决listFiles()为null问题
需求:将H盘下的所有文件复制到H:/All 文件夹中
思路:使用递归遍历整个目标目录
- 传入目标路径
- 判断是否是文件夹
是:调用listFiles()方法,得到File数组,重点内容接着执行1
否:复制文件到H:/All
源码:
package FunDemo;
import java.io.File;
import java.io.FileReader;
import java.io.FileWriter;
public class Demo2 {
static FileWriter fw = null;
public static void main(String[] args) throws Exception {
File file = new File("H:/");
sb(file);
}
private static void sb(File file) throws Exception {
if (file.isDirectory()) {
File[] files = file.listFiles();
if (files != null) {
for (File f : files) {
sb(f);
}
}
}
if (file.isFile()) {
FileReader fr = new FileReader(file.getAbsolutePath());
char[] cha = new char[1024];
fw = new FileWriter("H:/All/" + file.getName());
while (fr.read(cha) != -1) {
fw.write(cha, 0, cha.length);
fw.flush();
}
fw.close();
}
}
}
在解决这个问题 的过程中,遇到一个问题,其中一部分原代码片是这样的
if (file.isDirectory()) {
File[] files = file.listFiles();
for (File f : files) {
sb(f);
}
}
在执行的过程中,出现了空指针异常。为此,我有些疑惑,哪里来的空指针?
文件调用listFiles会返回null吗?文件夹呢?带着这个问题,首先我们来实验一下,数组出现空指针的情况;
情况一:
int []in = {};
for(int i:in) {
System.out.println(i);
}
控制台没有输出,但是并不会出现空指针异常。
情况二:
int []in = null;
for(int i:in) {
System.out.println(i);
}
此时,控制台会抛出空指针异常。java.lang.NullPointerException
所以,程序出现空指针异常的原因清楚了,因为存在file调用listFiles返回的数组是null。
又要问,为什么存在file调用listFiles返回的数组是null?
首先,我们来分析文件和文件夹调用listFiles是否都会有返回null的可能?
情况一:file为文件时
File file = new File("H:/test.txt");
File[] files = file.listFiles();
if (files == null) {
System.out.println("files为Null");//files为Null
}
此时,调用listFiles()返回null。
情况二:file为一个空的文件夹时
File fil=new File("H:/test");
File[] fils = fil.listFiles();
if (fils == null) {
System.out.println("fils为Null");//没有输出
}
此时,调用listFiles()没有输出,这很好理解,因为文件夹内为空,不会有输出。
然而,这就很奇怪了,因为在上述代码中,执行listFiles()前存在if (file.isDirectory()) 的前提,怎么会出现null的情况呢?
在这种情况下,我们查看javase api查看listFiles()的说明,发现存在这样一句话,如果抽象路径名不表示一个目录,或者发生 I/O 错误,则返回 null。唯一的解释就是发生了I/O错误,这是怎么回事呢?通过上网查阅资料,发现,存在一些文件/文件夹的访问权限很高,我们没有权限对其进行读写,此时就发生了所谓的I/O错误。
那么,知道了原因,就好办了,那么,这样可以解决吗?
if (file.isDirectory()) {
File[] files = null;
if (file.canRead()) {
file.listFiles();
for (File f : files) {
sb(f);
}
}
}
其实,这样也是不可以的,因为当不可读是files仍然是null,没有改变问题,所以解决方法就变成了最终样式:
if (file.isDirectory()) {
File[] files = file.listFiles();
if (files != null) {
for (File f : files) {
sb(f);
}
}
}
欢迎留言,欢迎指正~
java学习日志---File实例:实现复制整个文件夹、解决listFiles()为null问题的更多相关文章
- Java学习笔记——File类之文件管理和读写操作、下载图片
Java学习笔记——File类之文件管理和读写操作.下载图片 File类的总结: 1.文件和文件夹的创建 2.文件的读取 3.文件的写入 4.文件的复制(字符流.字节流.处理流) 5.以图片地址下载图 ...
- Java学习:File类
Java学习:File类 File类的概述 重点:记住这三个单词 绝对路径和相对路径 File类的构造方法 File类判断功能的方法 File类创建删除功能的方法 File类获取(文件夹)目录和文件夹 ...
- java学习一目了然——File类文件处理
java学习一目了然--File类文件处理 File类(java.io.File) 构造函数: File(String path) File(String parent,String child) F ...
- Java基础知识强化之IO流笔记50:IO流练习之 复制多级文件夹的案例
1. 复制多级文件夹的案例 需求:复制多级文件夹 数据源:E:\JavaSE\day21\code\demos 目的地:E:\ 分析: A:封装数据源File ...
- java中递归实现复制多级文件夹
常见的流的用法 递归实现复制多级文件夹 FileInputStream & FileOutputStream String content = null;//用来储存解码后的byte数组 in ...
- IO流(10)复制多级文件夹
import java.io.BufferedInputStream;import java.io.BufferedOutputStream;import java.io.File;import ja ...
- IO流-复制多极文件夹(递归实现)
package com.io.test; import java.io.BufferedInputStream; import java.io.BufferedOutputStream; import ...
- IO流案例:1.复制多级文件夹 2.删除多级文件夹
package copy; /* 需求:复制多级文件夹 复制d:\\itcast(包含文件和子文件夹)到模块目录下 分析: d:\\itcast a.txt b.txt javaweb a.xml b ...
- java 弹出选择目录框(选择文件夹),获取选择的文件夹路径
java 弹出选择目录框(选择文件夹),获取选择的文件夹路径 java 弹出选择目录框(选择文件夹),获取选择的文件夹路径:int result = 0;File file = null;String ...
随机推荐
- HDU5806 NanoApe Loves Sequence Ⅱ
NanoApe Loves Sequence Ⅱ Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/131072 K (Ja ...
- APDU报文【转】
本文转载自:http://www.cnbolgs.com/snail0404/p/5436348.html APDU # APDU # 定义:APDU(ApplicationProtocolDat ...
- leetcode 690. Employee Importance——本质上就是tree的DFS和BFS
You are given a data structure of employee information, which includes the employee's unique id, his ...
- 4.8 Using Ambiguous Grammars
4.8 Using Ambiguous Grammars It is a fact that every ambiguous grammar fails to be LR and thus is no ...
- 排名Top 100的Java类库
和去年一样,排名第一的类库,依旧是JUnit.基于它扩展的 JUnit Runner 占据第二名的位置,甚至是较旧的 junit.framework 此次也在第三名的位置.也就是说JUnit包揽了前三 ...
- bzoj4825
LCT 昨天调试一天没出来,今天推倒重写还是gg了,内心崩溃照着源代码抄,结果发现自己把原树fa和splay的fa一起维护,各种re... 其实我们手玩一下,发现其实树的形态变化很小,那么就可以用lc ...
- MogileFS介绍
MogileFS介绍 MogileFS 是一个开源的分布式文件存储系统,由LiveJournal旗下的Danga Interactive公司开发. Danga团队开发了包括 Memcached.Mog ...
- iPhone各尺寸 app界面设计尺寸规范
ip6: 375 * 667 pt @2x ~ 750 x 1334 ip6+: 414 * 736 pt @3x ~ 1242 x 2208 ip5: 320 * 568 pt @2x ~ 6 ...
- 洛谷 P1462 通往奥格瑞玛的道路(spfa+二分搜索)(4boy)
原题:http://www.luogu.org/problem/show?pid=1462#sub 4boy: 大意:给出n个城市,有m条路,每经过一个城市都要交钱,每经过一条道路都要扣HP,有HP上 ...
- nginx+thinkPhp配置虚拟主机和伪静态规则重写
/usr/local/nginx/conf/nginx.conf 进行配置 server { listen 80 default_server; #listen [: ...