0

こんにちは、ユーザーが選択する必要があるファイルを指定して、現在のディレクトリ、ファイル、サブディレクトリ、およびそれらのサブディレクトリのファイルを表示する方法を作成する必要がありました。私はタスクを達成し、次のコードは適切な出力を印刷しています。f.getParentFile() から印刷しています。それが必要です。代わりに再帰を使用したいと思います。私は再帰の概念を学ぼうとしています。基本ケースと誘導ステップが必要なのはわかっていますが、コードを再帰的に変更しようとすると、最初のサブディレクトリに到達したときに無限ループが発生します。フィードバックをお待ちしております。

非再帰的な作業コード

static void listFiles(File f)
{
    try
    {
        if (f.exists())
        {
            File dir = f.getParentFile();

            if (dir.isDirectory())
            {
                System.out.println("Directory:  " + dir );

                File[] list = dir.listFiles();
                for (int i = 0; i < list.length; i++)
                {
                    if (list[i].isDirectory())
                    {
                        System.out.println("\tSubdirectory:  " + list[i].getName() + "\tsize :" + (list[i].length()/1024) + "KB" );
                        File[] listFiles = list[i].getAbsoluteFile().listFiles();
                        for (int j = 0; j < listFiles.length; j++)
                        {
                            System.out.println("\t\tSubdirectory files:  " + listFiles[j].getName() + "\tsize :" + (listFiles[j].length()/1024) + "KB" );
                        }
                    }
                    else if (list[i].isFile())
                    {
                        System.out.println("\tFiles:  " + list[i].getName() + "\tsize :" + (list[i].length()/1024) + "KB" );
                    }
                }
            }
        }
        else throw new FileNotFoundException("File ******** does not exists");
    }
    catch(NullPointerException | FileNotFoundException e)
    {
        e.printStackTrace();
    }
}

再帰を試みる

static void listFiles(File f)
{
    try
    {
        if (f.exists())
        {
            File dir = f.getParentFile();

            if (dir.isDirectory())
            {
                System.out.println("Directory:  " + dir );

                File[] list = dir.listFiles();
                for (int i = 0; i < list.length; i++)
                {
                    if (list[i].isDirectory())
                    {
                        System.out.println("\tSubdirectory:  " + list[i].getName() + "\tsize :" + (list[i].length()/1024) + "KB" );
                        listFiles(list[i].getAbsoluteFile());
                    }
                    else if (list[i].isFile())
                    {
                        System.out.println("\tFiles:  " + list[i].getName() + "\tsize :" + (list[i].length()/1024) + "KB" );
                    }
                }
            }
        }
        else throw new FileNotFoundException("File ******** does not exists");
    }
    catch(NullPointerException | FileNotFoundException e)
    {
        e.printStackTrace();
    }
}
4

1 に答える 1