java IO流拷贝文件时出现文件夹“(拒绝访问)”的原因以解决方法

来源:互联网 发布:org.w3c.dom.node 编辑:程序博客网 时间:2024/06/08 19:35

今天在整理文件时,javascript视频教程文件,每个视频.mwk文件 都各自放在单独的一个文件夹里,比较分散,看的时候不能连贯着看。于是想用java IO流编程将它们拷贝出来并集中放置到一个文件夹里,方便观看。

 1. 列表内容public static void main(String[] args) throws IOException {        File parent = new File("D:\\JDK\\我的Java学习资料\\Java进阶开发学习\\前端\\03_JavaScript");        File goal = new File("D:\\JDK\\我的Java学习资料\\Java进阶开发学习\\前端\\03_JavaScript\\汇总");        File[] sourceFileArr = parent.listFiles();        int num = 0;        for (int i = 0; i < sourceFileArr.length; i++) {                    if (sourceFileArr[i].isDirectory()) {                File[] subFile = sourceFileArr[i].listFiles();                for (int j = 0; j < subFile.length; j++) {                          BufferedOutputStream bos =                             new BufferedOutputStream                            (new FileOutputStream(goal));                                       BufferedInputStream bis =                     new BufferedInputStream                    (new FileInputStream(new File(subFile[j].getPath())));                    int b;                    while((b = bis.read()) != -1) {                        bos.write(b);                    }                     bis.close();                     bos.close();                }            }        }    }

一开始我理所当然的写出了以上代码,将源文件sourceFileArr 中的视频直接向目标路径goal中拷贝,即有该语句:
BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(goal));

可是goal是一个文件夹的路径,我们无法(操作系统不支持)对一个文件夹进行操作,我们需要先指明拷贝后的副本的路径。这样java程序会先查看目标文件夹中是否存在该副本,如不存在则会自动创建该副本文件,然后将输出流写在该副本中,完成拷贝。所以以上语句应该为:
BufferedOutputStream bos = new BufferedOutputStream
(new FileOutputStream(new File(goal.toString() + “\” + sourceFileArr[i].getName())));

阅读全文
0 0
原创粉丝点击