标签:
写了几次删除文件夹下所有内容没写对,报nullpointer错误,也是无语了。不过还不理解文件的listfile()方法的存储机制。写了一个小程序感觉能搞清楚是怎么存的了。
import java.io.File; import java.io.IOException; public class deleteFile { public static void main(String[] args) { String str=""; File file = new File("C:/Users/xz/workspace/FileOperate"); File f[]=file.listFiles(); for (int i = 0; i < f.length; i++) { if(f[i].isDirectory()){ str=str+" "+i; System.out.print(f[i].getName()+" "); } } System.out.println(); System.out.println("数组长度为:"+f.length); System.out.println("文件夹在数组中所处位置为:"+str); } }
结果
bin src xz
数组长度为:5
文件夹在数组中所处位置为: 2 3 4
结果表明,数组仅仅存储了FileOperate文件夹下的文件,只是下一级的关系。
据此代码做出修改。。
//-----------------------------------------------------------------------------
最后发现是编写逻辑错误
修改后,正确执行。
import java.io.File; public class deleteFile { public static void main(String[] args) { File file = new File("C:/Users/xz/workspace/FileOperate/xz"); deleteAllFile(file); } public static void deleteAllFile(File file) { File f[] = file.listFiles(); for (int i = 0; i < f.length; i++) { if (f[i].isDirectory() && FileIsNotNull(f[i])) { deleteAllFile(f[i]); } if (f[i].isDirectory() && !FileIsNotNull(f[i])) { f[i].delete(); } else { f[i].delete(); } } } public static boolean FileIsNotNull(File file) { File f1[] = file.listFiles(); if (f1.length > 0) { return true; } else { return false; } } }
标签:
原文地址:http://www.cnblogs.com/xz-blogs/p/4964473.html