Java方法遞歸調(diào)用實例解析
更新時間:2020年02月05日 08:58:43 作者:古墩古墩
這篇文章主要介紹了Java方法遞歸調(diào)用實例解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
這篇文章主要介紹了Java方法遞歸調(diào)用實例解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
/*
關(guān)于方法的遞歸調(diào)用
1、什么是遞歸?
-方法自身調(diào)用自身
a(){
a(){
}
}
2、遞歸是很耗費棧內(nèi)存的,遞歸算法可以不用的時候盡量不用
3、一下程序運行的時候發(fā)生了這樣一個錯誤【不是異常,是錯誤Error】:
java.lang.StackOverflowErroe
棧內(nèi)存溢出錯誤。
錯誤放生無法挽回,只有一個結(jié)果,就是JVM停止工作
4、遞歸必須有結(jié)束條件,沒有結(jié)束條件一定會發(fā)生棧內(nèi)存溢出錯誤
5、遞歸即使有了結(jié)束條件,即使結(jié)束條件是正確的,也可能會發(fā)生棧內(nèi)存溢出錯誤,
因為遞歸的太深了,棧內(nèi)存被占滿。
注意:
遞歸如果可以不使用,盡量不使用。
但是有些情況下,該功能的實現(xiàn)必須一覽遞歸實現(xiàn),比如 目錄拷貝
*/
public class Method01{
// 主方法
public static void main(String[] args){
doSome();
}
// 調(diào)用doSome方法
// 以下的代碼片段雖然只有一份
// 但是可以被重復的調(diào)用,并且只要調(diào)用doSome方法就會在棧內(nèi)存中開辟一塊所屬的內(nèi)存空間,
public static void doSome(){
System.out.println("doSome begin!");
doSome();//這行代碼不結(jié)束,下一行代碼是不能執(zhí)行的
System.out.println("doSome over!");
}
}
/*
不使用遞歸計算1-N的求和【可以不用遞歸,盡量不用遞歸】
*/
public class Method01{
// 主方法
public static void main(String[] args){
// 計算1-4的和
// int n = 4;
// int sum = 0;
// for(int i=1;i<=n;i++){
// sum += i;
// }
// System.out.println(sum);
// 直接調(diào)用方法即可
int n = 4;
int resultVal=sum(n);
System.out.println(resultVal);
}
// 單獨定義一個方法,這是一個獨立的功能,可以完成1-N的求和
public static int sum(int n){
int result = 0;
for(int i=1;i<=n;i++){
result+=i;
}
return result;
}
}
/*
使用遞歸計算1-N的和
*/
public class Method01{
// 主方法
public static void main(String[] args){
// 1-4的和
int n = 4;
int retValue = sum(n);
System.out.println(retValue);
}
public static int sum(int n){
// 4+3+2+1
if(n == 1){
return 1;
}
return n + sum(n-1);
}
}

/*
先不使用遞歸計算N的階乘
5的階乘:
5*4*3*2*1
*/
public class Method01{
// 主方法
public static void main(String[] args){
int n = 5;
int retValue = method(n);
System.out.println(retValue);//120
}
public static int method(int n){
int result = 1;
for(int i=n;i>0;i--){
result *= i;
}
return result;
}
}
/*
使用遞歸計算N的階乘
5的階乘:
5*4*3*2*1
*/
public class Method01{
// 主方法
public static void main(String[] args){
int n = 5;
int retValue = method(n);
System.out.println(retValue);//120
}
public static int method(int n){
if(n==1){
return 1;
}
return n*=method(n-=1);
}
}
遞歸內(nèi)存分析:

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
SpringCloud如何實現(xiàn)Zuul集群(負載均衡)
這篇文章主要介紹了SpringCloud如何實現(xiàn)Zuul集群(負載均衡)的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07
Springboot項目的Mapper中增加一個新的sql語句
本文主要介紹了Springboot項目的Mapper中增加一個新的sql語句,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-05-05
使用SpringBoot動態(tài)切換數(shù)據(jù)源的實現(xiàn)方式
在我們企業(yè)項目開發(fā)的過程中,有的時候,一個項目需要在運行時,根據(jù)某種條件選擇使用哪個數(shù)據(jù)源,那么此時該怎么進行動態(tài)切換呢,本文給大家例舉一種常見的實現(xiàn)方式,文中有詳細的實現(xiàn)步驟,需要的朋友可以參考下2023-12-12
Spring Boot整合Spring Data Jpa代碼實例
這篇文章主要介紹了Spring Boot整合Spring Data Jpa代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-11-11
聊聊Controller中RequestMapping的作用
這篇文章主要介紹了Controller中RequestMapping的作用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-02-02

