黑马程序员--递归方法参数的自增自减
2015-06-22 21:42
591 查看
下面的例子是在递归练习中自己犯得一个小错误:
public class DiGui {
public static void main(String[] args) {
Int value_1=method_1(1);//方法是有逻辑错误的,内存会溢出
Int value_2=method_2(1);
}
public static int method_1(int x){
if(x==100)
return x;
return x+method_1(x++);//在参数位置加自增自减符号要特别注意
}
public static int method_2(int x){
if(x==100)
return x;
return x+method_2(++x);
}
}
本意是用递归写一个从一个小于100的数字累加到100的和的值,本来也不难,随手就写了method_1,一运行才发现内存溢出,仔细一分析发现犯了一个小错误,method_1中的逻辑错误就是递归中,调用自身方法传递进去的参数值是恒定不变的,会一直递归调用自身函数而不会达到跳出递归的条件。即main方法中每次调用method_1方法传入的值都是“1”,是个死循环。
其实上面的错误也正好验证了java参数的值传递问题,参数值传入方法以后,再对参数的操作已经和方法内的值没关系了。
public class DiGui {
public static void main(String[] args) {
Int value_1=method_1(1);//方法是有逻辑错误的,内存会溢出
Int value_2=method_2(1);
}
public static int method_1(int x){
if(x==100)
return x;
return x+method_1(x++);//在参数位置加自增自减符号要特别注意
}
public static int method_2(int x){
if(x==100)
return x;
return x+method_2(++x);
}
}
本意是用递归写一个从一个小于100的数字累加到100的和的值,本来也不难,随手就写了method_1,一运行才发现内存溢出,仔细一分析发现犯了一个小错误,method_1中的逻辑错误就是递归中,调用自身方法传递进去的参数值是恒定不变的,会一直递归调用自身函数而不会达到跳出递归的条件。即main方法中每次调用method_1方法传入的值都是“1”,是个死循环。
其实上面的错误也正好验证了java参数的值传递问题,参数值传入方法以后,再对参数的操作已经和方法内的值没关系了。
相关文章推荐
- 常见的sql面试题
- PHP 程序员如何设计一个爬虫程序
- 黑马程序员——变量、printf函数、scanf函数
- 黑马程序员--多线程--5th
- 黑马程序员——高新技术---反射
- 黑马程序员——初识JAVA
- 黑马程序员---iOS编程效率提高必备
- 实习面试题目总结一
- 微软经典的算法面试100题之32题
- SQL面试题
- 黑马程序员--java反射学习笔记
- ETL架构师面试题(这篇文章太棒了)
- 面试题总结1
- 黑马程序员---MAC OS X系统终端常用命令
- 剑指offer-第四章解决面试题的思路(顺序打印矩阵)
- 优秀的程序员”应该是这样的
- 黑马程序员--Java学习日记之面向对象(多态和匿名内部类)
- 关于如何成为一名优秀的程序员
- 黑马程序员--Java学习日记之面向对象(封装,this和static,继承)
- 重构是每个程序员的洗髓经