A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 魏征 中级黑马   /  2012-5-4 16:30  /  2468 人查看  /  7 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

下列是一个指定路径下打印出所有文件名。应用的是递归,请问递归在内存中是如何实现的?有没有别的方法可以在指定路径下打印其所有的文件名的方法?请高手指教
public static void main(String[] args)
{
  File f=new File("d:\\java1");
  listFile(f);
}
public static void listFile(File dir)
{
  
  File []arr=dir.listFiles();
  for (File f:arr )
  {
   if (f.isDirectory())
   {
    System.out.println(f.getName()+"::");
    listFile(f);
   }
   else
   System.out.println(f.getName());
  }
}

评分

参与人数 1技术分 +1 收起 理由
贠(yun)靖 + 1

查看全部评分

7 个回复

倒序浏览
楼主,递归最重要的两个因素之一便是出口,你的程序进来并没用判断 dir是否是文件,若是文件,你这程序便报错了。
你的程序使用的是深度搜索也就是所谓的DFS了,既然是递归当然也可以非递归实现了,主要要深度搜索,广度搜索,迭代实现,这里就给你举个广度优先搜索的非递归实现
import java.io.File;
import java.util.LinkedList;;


public class Test
{
public static void main(String[] args)
{
  File f=new File("d:\\java1");
  listFile(f);
}
public static void listFile(File dir)
{
  if(dir.isFile())
  {
          System.out.println(dir.getName());
          return;
  }
  LinkedList<File> list = new LinkedList<>();//实现了Queue 接口
  list.add(dir);
  while(list.size() > 0)
  {
          File file = list.pollFirst();
          if(file.isFile())
                  System.out.println(file.getName());
          else {
                System.out.println(file.getName()+"::");
                for(File file2:file.listFiles())
                {
                        list.add(file2);
                }
        }
  }
}
}
其他若也想了解,可以进一步交流算法经验噢!

评分

参与人数 1技术分 +1 收起 理由
贠(yun)靖 + 1 赞一个!

查看全部评分

回复 使用道具 举报
上面的那位哥们答不错,我只补充一下递归在内存中是如何实现。它是同方法栈实现的,每次调用一个方法时,方法会进栈,遵循的是先进后出的原则。下面发现张图:
E:\javase20120302\day04\方法栈.bmp
回复 使用道具 举报
上面的那位哥们答不错,我只补充一下递归在内存中是如何实现。它是同方法栈实现的,每次调用一个方法时,方法会进栈,遵循的是先进后出的原则。下面发现张图:
E:\javase20120302\day04\方法栈.bmp
回复 使用道具 举报
徐慧书 发表于 2012-5-4 21:58
楼主,递归最重要的两个因素之一便是出口,你的程序进来并没用判断 dir是否是文件,若是文件,你这程序便报 ...

我的程序不会报错的,
else
   System.out.println(f.getName());
如果非目录便打印其文件名。
回复 使用道具 举报
上面的那位哥们答不错,我只补充一下递归在内存中是如何实现。它是同方法栈实现的,每次调用一个方法时,方法会进栈,遵循的是先进后出的原则。下面发现张图:

方法栈.jpg (56.68 KB, 下载次数: 49)

方法栈.jpg

评分

参与人数 1技术分 +2 收起 理由
贠(yun)靖 + 2 很给力!

查看全部评分

回复 使用道具 举报
魏征 发表于 2012-5-4 23:11
我的程序不会报错的,
else
   System.out.println(f.getName());

File []arr=dir.listFiles();
  for (File f:arr )
可以仔细看看这两句代码,再者便是把d:\\java1改成某个文件试试
回复 使用道具 举报
递归要不断的调用的方法,不断分配空间,效率一般比较低,可以用楼上大侠们算法实现,一般能用递归实现的,用循环就可以实现
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马