结合File类浅析递归的使用
递归算法就是方法自身直接或者间接地调用到了自身,它是一种写起来很简单,但理解起来不那么简单的算法。
一个功能在被重复地调用,并且运算的结果和上一次的调用有关, 这种时候,可以使用递归。
* 注意:
* 1.递归一定要明确递归结束的条件,否则会栈溢出
* 2.注意解决问题的递归次数,如果次数过多,也会发生栈溢出。
比较经典的例子有斐波那契数列、汉诺塔等,这里我们谈谈递归在File类中的使用。
一、牛刀小试
先看,两个简单的例子来了解递归。
public class RecursionDemo {
public static void main(String[] args) {
System.out.println(getSum(6));//
toBinary(9);//
}
//十进制转换为二进制
public static void toBinary(int num){
if(num>0){
toBinary(num/2);
System.out.print(num%2);
}
}
//连续的加法
public static int getSum(int num){
if(num==1)
return 1;
return num+getSum(num-1);
}
}
二、File类应用1
练习:列出某目录下的内容(包含子目录中的内容),
即进行深度遍历.并且显示出目录层级。
package www.brighten.io;
import java.io.File;
public class FileTraversalTest {
public static void main(String[] args) {
//定义目录层级
int level=0;
//创建要列出的目录
File dir=new File("D:\\workplace\\BumpGame\\src");
listAll(dir,level);
}
public static void listAll(File dir, int level) {
System.out.println(getSpace(level)+dir.getName());
File[] files=dir.listFiles();
level++;
for (int i = 0; i < files.length; i++) {
if(files[i].isDirectory()){//如果是目录
listAll(files[i], level);//递归
}
else//如果是文件
{
//打印出文件的名字,并在文件名前面加上相应目录层级的缩进
System.out.println(getSpace(level)+files[i].getName());
}
}
}
/**
* 计算不同目录层级的缩进
* @param level 目录层级
* @return String类型的缩进符号
*/
public static String getSpace(int level) {
StringBuilder space=new StringBuilder();
space.append("|--");
for (int i = 0; i <= level; i++) {
space.insert(0, " ");
}
return space.toString();
}
}
程序输出如下:
|--src
|--com
|--wsw
|--bump
|--Ball.java
|--Board.java
|--BumpGame.java
|--MoveObject.java
|--思路
三、File类练习2
练习:删除一个目录。
思路:需要从里向外删除,要进行深度遍历,使用递归算法。
package www.brighten.io;
import java.io.File; public class RemoveDirTest { public static void main(String[] args) { File dir=new File("C:\\Test");
removeDir(dir);
} public static void removeDir(File dir) {
File[] files=dir.listFiles();
for(File file:files){
if(file.isDirectory()){
removeDir(file);
}else{
System.out.println(file+"::"+file.delete());//删除文件
}
}
System.out.println(dir+"::"+dir.delete());//删除内容已经为空的目录
} }
程序输出如下,可以看出删除的顺序是把目录中的内容依次删除,然后再删掉这个目录,递归下去,最后删除最上一级的目录。
所有做删除结果反馈的语句都显示为“true”,可见目录删除成功。
C:\Test\background.png::true
C:\Test\Cell.png::true
C:\Test\Test1\L.png::true
C:\Test\Test1\O.png::true
C:\Test\Test1::true
C:\Test\Test2\Test3\I.png::true
C:\Test\Test2\Test3\J.png::true
C:\Test\Test2\Test3::true
C:\Test\Test2::true
C:\Test::true
结合File类浅析递归的使用的更多相关文章
- Java IO体系之File类浅析
Java IO体系之File类浅析 一.File类介绍 位于java.io下的Java File类以抽象的方式代表文件名和目录路径名.该类主要用于文件和目录的创建.文件的查找和文件的删除等.File对 ...
- File类、递归
File类.递归 1.1File类概述 java.io.File表示文件和目录路径名的抽象类.可以对文件和文件夹进行创建删除.获取.判断.遍历等功能. 1.2路径\文件分割符,相对路径绝度路径 1.2 ...
- 01 语言基础+高级:1-8 File类与IO流_day08【 File类、递归】
day08[File类.递归] 主要内容 File类 递归 教学目标 能够说出File对象的创建方式 能够说出File类获取名称的方法名称 能够说出File类获取绝对路径的方法名称 能够说出File类 ...
- 黑马程序员——JAVA基础之File类,递归,打印流,合并切割流
------- android培训.java培训.期待与您交流! ---------- File类 用来将文件或者文件夹封装成对象 方便对文件与文件夹的属性信息进行操作. File对象可以作为参数传递 ...
- Java基础---Java---IO流-----File 类、递归、删除一个带内容的目录、列出指定目录下文件夹、FilenameFilte
File 类 用来将文件或者文件夹封装成对象 方便对文件与文件夹进行操作. File对象可以作为参数传递给流的构造函数 流只用操作数据,而封装数据的文件只能用File类 File类常见方法: 1.创建 ...
- File类,递归
File类 File文件和目录路径名的抽象表示形式.即,Java中把文件或者目录(文件夹)都封装成File对象. File类包含 路径 path E:\... 目录 direct ...
- Java中的File类,递归是什么?
一.IO概述 当需要把内存中的数据存储到持久化设备上这个动作称为输出(写)Output操作. 当把持久设备上的数据读取到内存中的这个动作称为输入(读)Input操作. 因此我们把这种输入和输出动作称为 ...
- Java【File类、递归】
File 1.在io包中 操作电脑中的文件和文件夹 java.io.File 类是文件和目录路径名的抽象表示,主要用于文件和目录的创建.查找和删除等操作. 我们可以使用File类的方法 创建一 ...
- java基础知识回顾之javaIO类--File类应用:递归深度遍历文件
代码如下: package com.lp.ecjtu.File.FileDeepList; import java.io.File; public class FileDeepList { /** * ...
随机推荐
- GIT学习笔记(1):创建版本库
GIT学习笔记(1):创建版本库 创建版本库 1.创建合适目录并初始化为仓库 版本库即需要交由Git进行版本控制的目录,其下所有文件的修改.删除,Git都能跟踪还原. 说明:初始化后,当前目录下会多出 ...
- uva1025 dp
这题说的是给了n个车站 从1号 车站到 n号车站,有m1辆车从1 开往n 有m2 辆车从n 开往1 一个人从1 车站 到达n 车站在T 时刻 要求再 车站呆的时间尽量少 dp[i][j] 表示 在 第 ...
- 使用Linux重定向解决nohup.out无写权限问题
■场景 执行nohup命令的时候,经常会出现下面这种没有写入权限的错误. nohup: ignoring input and appending output to `nohup.out'nohup: ...
- 20145315 《Java程序设计》第八周学习总结
20145315 <Java程序设计>第八周学习总结 教材学习内容总结 第十五章通用API 15.1日志 15.1.1日志API简介 使用日志的起点是logger类,logger实例的创建 ...
- 什么是TensorFlow Serving
答:1. 从Serving 可以看出,与服务有关; 2. 那么为啥还有TensorFlow的前缀?肯定与TensorFlow有着很大的关系: 3. 那么Tensorflow是用来干什么的呢?Tenso ...
- JMeter的下载以及安装使用
下载 https://jmeter.apache.org/download_jmeter.cgi 安装 无须安装,解压之后即可使用. 解压到C:\Program Files\apache-jmeter ...
- adb: failed to install xxx.apk: Failure [INSTALL_FAILED_UPDATE_INCOMPATIBLE: Package com.xxx.deliveryrobot signatures do not match the previously installed version; ignoring!]
解决方法:我是在安装软件时出现的这个错误,先卸载再安装即可 卸载: adb uninstall "com.yourapp.yourapp" 安装: adb install your ...
- Qt5_vs2013_error_C2001: 常量中有换行符__ZC
ZC: 这里是解决 Windows平台下的这个 编译error :“error C2001: 常量中有换行符”. ZC: 我现在(20161221)的处理方式:vs2010或vs2015 将cpp文件 ...
- kue
尝试着看英文的文档,你发现他其实并不难. https://www.npmjs.com/package/kue
- Python——列表表达式
https://www.cnblogs.com/xuyuanyuan123/p/6718403.html