参数
**参数类型:**参数像是一个占位符。当方法被调用时,传递值给参数。这个值被称为实参或变量。参数列表是指方法的参数类型、顺序、和参数的个数。参数是可选的,方法可以不包括任何参数。
- 形式参数:在方法被调用的时候用于接收外界输入的数据
- 实参:调用时实际传给方法的数据。
命令行传参
-
有时候你希望运行一个程序的时候再传递给它消息。这要靠传递命令行参数给main()函数实现。
public class CommandLine{ public static void main(String args[]){ for(int i= 0; i<args.length;i++){ System.out.println("args["+i+"]:"+args[i]); } } }
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FXDlpQXG-1600826188636)(C:\Users\DELL\AppData\Roaming\Typora\typora-user-images\image-20200922191954018.png)]
直接运行class文件找不到,需要调整到包下运行
可变参数
-
JDK1.5开始,java支持传递同类型的可变参数给一个方法。
-
在方法声明中,在指定参数类型后加一个省略号(…)
-
一个方法中只能指定一个可变参数,它必须是方法的最后一个参数。任何普通的参数必须在它之前声明。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Ih4A1VLK-1600826188648)(C:\Users\DELL\AppData\Roaming\Typora\typora-user-images\image-20200922194706455.png)]
递归
-
A方法调用B方法,我们很容易理解!
-
递归就是:A方法调用A方法!就是自己调用自己
-
利用递归可以用简单的程序来解决一些复杂的问题。它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可以描述出解题过程所需要的的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合。
-
递归的结构包括两个部分:
- 递归头:什么时候不调用自身方法。如果没有头,将陷入死循环。
- 递归体:什么时候需要调用自身方法。
public class Demo07 {
public static void main(String[] args) {
method();
}
// 定义一个计数的变量count,作为递归结束的条件
public static int count = 0;
public static void method() {
if (count++ < 10) {// 递归体
System.out.println("测试递归");
method();// 调用方法自己就叫递归
} else {// 递归头
return;// 小提示:return除了用于返回值以外,还有结束程序的功能哦
}
}
}
- 递归结构的优缺点是什么?
优点:将问题逐渐简单化,例如计算阶乘
缺点:会占用大量的系统堆栈,内存耗用多,在递归调用层次多时速度比循环慢的多。