[NIO.2] 第三十篇 递归操作简述

你可能知道,在编程中使用递归技术一直有争议,但是它的确简化了一些编程任务。简单来说,递归就是应用程序调用自身的过程。比如计算阶乘,计算费氏数列等都是非常著名的可用递归方式来完成的任务。下面看看一个计算阶乘(n!=1*2*3*4...*n)的例子,注意看程序如何调用自身:

/** 
* Calculate the factorial of n (n! = 1 * 2 * 3 * … * n).
*
* @param n the number to calculate the factorial of.
* @return n! - the factorial of n.
*/
static int fact(int n) {

// Base Case:
// If n <= 1 then n! = 1.
if (n <= 1) {
return 1;
}
// Recursive Case:
// If n > 1 then n! = n * (n-1)!
else {
return n * fact(n-1);
}
}


如果你对递归技术已经比较了解,那么接下来介绍一下在 NIO.2 中使用到的递归技术。

很多程序都需要访问目录树中的所有文件,这是使用递归操作的好时机。在进行删除、拷贝和移动目录树的时候经常会使用到递归操作。基于此,NIO.2 将递归遍历文件树的过程封装到了一个接口中,这个接口就是 java.nio.file.FileVisitor。

文章来源:[url]http://www.aptusource.org/2014/04/nio-2-recursive-operations/[/url]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值