I/O————File对象

File文件对象

文件和文件夹都是用File代表

创建一个文件对象,(并不会有真正的文件或文件夹被创建)

File f1 = new File("d:/lolfilder");
        System.out.println("f1的绝对路径:"+f1.getAbsolutePath());
        File f2 = new File("lol.exe");
        System.out.println("f2的绝对路径:"+f2.getAbsolutePath());
        File f3 = new File(f1, "lol.exe");
        System.out.println("f3的绝对路径:"+f3.getAbsolutePath());
        //mkdir()创建文件夹 父文件夹不存在则创建失败
        //f3.mkdir();
        //mkdirs()创建文件夹 父文件夹不存在则创建父文件夹然后再创建该文件夹
        f3.mkdirs();
        System.out.println("f3是否存在:"+f3.exists());
        //list()返回一个字符串数组包,含当前文件夹下的所有文件名称
        String[] fStrings=f1.list();
        for(String s:fStrings) {
            System.out.println(s);
            
        }
        

遍历文件夹练习

遍历C:\WINDOWS目录目录下所有的文件(不用遍历子目录)找出这些文件里,最大的和最小(非0)的那个文件,打印出他们的文件名

要求:最小的文件不能是0长度

实现思路:不遍历子目录较简单,建立最大文件和最小文件对象,然后用循环保证最大和最小。要注意最小文件不能是0,所以要给min一个值,要不然大小为0的文件比所有文件都小

public class test {
/**
 * 
 * 遍历c盘windows文件夹下的所有文件(不包括子目录下的),并列出最大和最小的
 */
    public static void main(String[] args) {
        File file = new File("C:\\Windows");
        File max=new File(" ");
        File min = new File(" ");
        //用listFiles方法获得一个File类型的数组
        File []fs = file.listFiles();
        //foreach
        for(File f:fs) {
            
        //给min一个初值,要不然一直是最小的
        if(min.length()==0)
             min=max;
        //比max大的,取代max    
        if(max.length()<f.length()) {
            max= f;
        }
        
        //比min小的取代min
        if(min.length()>f.length()&&f.length()!=0) {
            min= f;
        }
        
            System.out.println("文件名为:"+f.getAbsolutePath()+"大小为:"+f.length());
        }
        
        System.out.println("最大文件为:"+max.getAbsolutePath()+"大小为:"+max.length());
        System.out.println("最小文件为:"+min.getAbsolutePath()+"大小为:"+min.length());
        

    }

}

接下来是要遍历子目录:

实现思路就是使用递归,如果它当前文件是文件夹就继续调用该方法

public class List {
    /**
     * 
     * 使用递归遍历c盘windows文件夹下的所有文件(包括子目录下的),并列出最大和最小的
     */
    
    File max = new File(" ");
    File min = new File(" ");
    
    
    public void listFile(File file) {
        
            //如果f是一个文件夹,开始递归
            if(file.isDirectory()) {
                 File[] fs = file.listFiles();
                    if(null!=fs)
                    for (File f : fs) {
                        listFile(f);
                    }
            }
            //如果file是文件
            if(file.isFile()) {
            
            
            //给min一个初值,要不然一直是最小的
            if(min.length()==0)
                 min=max;
            //比max大的,取代max    
            if(max.length()<file.length()) {
                max= file;
            }
            
            //比min小的取代min
            if(min.length()>file.length()&&file.length()!=0) {
                min= file;
            }

            
            return;
        }
        }
        
    

}

 

posted @ 2019-05-04 09:49  奥兔man  阅读(598)  评论(0编辑  收藏  举报