目录

JAVA递归


目录

Java的递归

  • 方法自己调用自己,这就是方法递归。所以:递归必须要有结束条件。

当递归时程序没有结束条件,一定会发生:

栈内存溢出错误:StackOverflowError
所以:递归必须要有结束条件。
  • JVM发生错误之后只有一个结果,就是退出JVM。

  • 递归假设是有结束条件的,就一定不会发生栈内存溢出错误吗?

    假设这个结束条件是对的,是合法的,递归有的时候也会出现栈内存溢出错误。
    因为有可能递归的太深,栈内存不够了。因为一直在压栈。
    

在实际的开发中,不建议轻易的选择递归,能用for循环while循环代替的,尽量使用循环来做。因为循环的效率高,耗费的内存少。递归耗费的内存比较大,另外递归的使用不当,会导致JVM死掉。(但在极少数的情况下,不用递归,这个程序没法实现。)

  • 在实际的开发中,假设有一天你真正的遇到了:StackOverflowError 解决问题的思路: 首先第一步: 先检查递归的结束条件对不对。如果递归结束条件不对,必须对条件进一步修改,直到正确为止。

    ​ 第二步:假设递归条件没问题,怎么办? ​ 这个时候需要手动的调整JVM的栈内存初始化大小。可以将栈内存的空间调大点。(可以调整大一些。) ​ 第三步:调整了大小,如果运行时还是出现这个错误, ​ 没办法,只能继续扩大栈的内存大小。(java -X)这个可以查看调整堆栈大小的参数

递归的代码

栈溢出错误
public class JavaTest{
	public static void main(String[] args) {
		dosome();
	}
	public static void dosome() {
		System.out.println("dosome begin");
		dosome();
		System.out.println("dosome end");
	}
}

递归没有结束条件的时候会发生栈内存溢出错误

./递归没有结束条件的时候会发生栈内存溢出错误.png

不使用递归计算1-n的和
import java.util.Scanner;

public class JavaTest{
	public static void main(String[] args) {
		Scanner sc =new Scanner(System.in);
		System.out.println("请输入一个数字");
		int input = sc.nextInt();
		System.out.println("1-"+input+"的和是:"+sum(input));
	}
	public static int sum(int num) {
		int result=0;
		for(int i=0;i<=num;i++) {
			result+=i;
		}
		return result;
	}
}
使用递归计算1-n的和
import java.util.Scanner;

public class JavaTest{
	public static void main(String[] args) {
		Scanner sc =new Scanner(System.in);
		System.out.println("请输入一个数字");
		int input = sc.nextInt();
		System.out.println("1-"+input+"的和是:"+sum(input));
	}
	public static int sum(int num) {
		if(num==1) {
			return 1;
		}
		return num+sum(num-1);
	}
}

递归原理

./递归原理.png