递归文件查找

递归—什么是递归?

递归算法是一种直接或者间接调用自身函数或者方法的算法。Java递归算法是基于Java语言实现的递归算法。递归算法的实质是把问题分解成规模缩小的同类问题的子问题,然后递归调用方法来表示问题的解。递归算法对解决一大类问题很有效,它可以使算法简洁和易于理解。

递归:说白了,就是自己调用自己

下面是Android利用递归算法查找文件的例子,大家来看看吧···········

public class MainActivity extends Activity {
Handler handler=new Handler();
List<String> strPath=new ArrayList<String>();
private TextView tv;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        tv = (TextView) findViewById(R.id.tv);
        //因为递归占用内存较大,比较耗时所以要放在线程里
        handler.post(new Runnable() {
            @Override
            public void run() {
                // TODO Auto-generated method stub
                //获取sd卡根目录文件对象
                File rootFile=Environment.getRootDirectory().getAbsoluteFile();
                find(rootFile);
                //当文件查找完毕之后就可以输出了
                tv.setText(strPath.toString());

            }
        });

    }
    //文件查找递归方法;
    private void find(File file) {
        //获取文件对象的文件对象列表
        File[] files=file.listFiles();
        //如果文件是个空目录直接return
        if(files==null)return;
        for(int i=0;i<files.length;i++){
            if(files[i].isDirectory()){
                //判断该文件对象是不是目录,如果是,就开始递归
                find(files[i]);
            }else{
                //如果不是目录,说明它是个文件,下面我们可以再判断该文件的后缀名进行文件查找操作
                if(files[i].getName().endsWith("jpg")){
                    /*这边我是判断的是jpg文件,如果想要查找其他的可更改
                     * 查找完后将文件目录添加到List集合中
                     */
                    strPath.add(files[i].getAbsolutePath());
                }
            }
        }

    }


}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值