三、Java方法
Java的方法类似与其他语言的函数,是一段用来完成特定功能的代码片段。
- 方法是解决一类问题的步骤的有序组合;它包含于类或对象中;在程序中被创建,在其他地方被引用。
- 设计方法的最好原则:方法的本意是功能块,就是实现某个功能的语句块的集合。设计方法时最好保持方法的原子性,即一个方法只完成一个功能,能够利于后期的扩展。
方法包含一个方法头和一个方法体:
修饰符 返回值类型 方法名(参数类型 参数名){
...
方法体
...
return 返回值;
}
方法的调用:
当方法返回一个值的时候,方法调用通常被当做一个值。如果方法返回值是void,方法调用一定是一条语句。
方法的重载:
重载就是在一个类中,有相同的函数名称,但是形参不同的函数。
方法的重载的规则:
1.方法名称必须相同。
2.参数列表必须不同(个数不同、类型不同、参数排列顺序不同等)。
3.方法的返回类型可以相同也可以不同。
4.仅仅返回类型不同不足以成为方法的重载。(?)
可变参数:
JDK 1.5开始,Java支持传递同类型的可变参数给一个方法。在方法声明中,在指定参数类型后加一个省略号(…)。一个方法只能指定一个可变参数,它必须是方法的最后一个参数。任何普通的参数必须在它之前声明。
public class Demo03 {
public static void main(String[] args) {
printMax(10.2,16.5,66,77.2);
printMax(new double[]{1,3,55.2});
}
public static void printMax(double... numbers){
if (numbers.length == 0){
System.out.println("No argument passed");
return;
}
double result = numbers[0];
for (int i = 1;i < numbers.length;i++){
if (numbers[i] > result){
result = numbers[i];
}
}
System.out.println("The max value is " + result);
}
}
递归:
A方法调用A方法,自己调用自己就叫做递归。
递归策略只需要少量的程序就可以描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合。
递归结构包括两个部分:
递归头:什么时候不调用自身方法。如果没有头,将会陷入死循环。
递归体:什么时候需要调用自身方法。
public class Demo04 {
public static void main(String[] args) {
System.out.println(f(5));
}
public static int f(int n){
if (n ==1){
return 1;
}else {
return n * f(n-1);
}
}
}
以上均为在B站学习中的笔记。如有错误,欢迎指正。
学习链接在这里!