【JavaSE基础笔记 · 艮】Java方法详解

由 MisakaStone 发布

1 何谓方法

Java方法是语句的集合,它们在一起执行一个功能。

  • 方法是解决一类问题的步骤的有序组合
  • 方法包含于类或对象中
  • 方法在程序中被创建,在其他地方被引用

System.out.println()中,System是类,out是对象,println()是方法。

方法的设计原则:方法的本意是功能块,就是实现某个功能的语句块的集合。我们设计方法的时候,最好保持方法的原子性,就是一个方法只完成一个功能,这样利于我们后期的扩展。


2 方法的定义

Java的方法类似于其他语言的函数,是一段用来完成特定功能的代码片段

方法包含一个方法头和一个方法体。下面是一个方法的所有部分:

  • 修饰符:可选,告诉编译器如何调用该方法,定义了该方法的访问类型。
  • 返回值类型:返回值的数据类型,若没有返回值,returnValueType是关键字void。
  • 方法名:方法的实际名称,方法名和参数表共同构成方法签名
  • 参数类型:参数像是一个占位符。当方法被调用时,传递值给参数,这个值被称为实参变量。参数列表是指方法的参数类型、顺序和参数的个数。参数可选,方法可不包含任何参数。

    • 形式参数:在方法被调用时用于接收外界输入的数据。
    • 实参:调用方法时实际传递给方法的数据。
  • 方法体:方法的具体语句,定义该方法的功能。
public static int getMax(int num1, int num2) {

    int max;

    if (num1 == num2) {
        System.out.println("Two numbers are equal.");
        return 0;
    } else if (num1 > num2) {
        max = num1;
    } else {
        max = num2;
    }
    
    return max;

}

// return 0 可用于结束方法


3 方法的调用Java

调用格式

对象名.方法名(实参列表)

Java支持两种调用方式,根据方法是否返回值来选择。

当方法返回一个值的时候,方法调用通常被当作一个值,例如:

int larger = getMax(10, 20);

当方法返回类型为void时,方法调用一定是一条语句,例如:

System.out.println("Welcome to MisakaBlog!");

4 方法的重载

重载就是在一个类中,有相同的函数名称,但形参不同的函数。

方法的重载规则:

  • 方法名必须相同。
  • 参数列表必须不同(参数个数、类型或顺序不同)。
  • 返回类型可相同也可不相同。
  • 仅返回类型不同不足以成为方法的重载。

实现理论:方法名称相同时,编译器会根据调用方法的参数个数、参数类型等去逐个匹配,以选择对应的方法,如果匹配失败,则编译器报错。


5 可变参数

JDK1.5开始,Java支持传递同类型的可变参数给一个方法。

方法声明中,在指定参数类型后面加一个省略号(...)以实现可变参数的传递。

一个方法只能生成一个可变参数,它必须是方法的最后一个参数。任何普通参数必须在它之前声明。

public void printMax(int... numbers) {

    int max = numbers[0];

    for (int temp : numbers) {
        if (max <= temp) {
            max = temp;
        }
    }

    System.out.println("Max = " + max);

}

6 递归讲解

递归就是自己调用自己。

利用递归可以用简单的程序来解決一些复杂的向题。它通常把一个大型复杂的向题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合。

递归结构包含两个部分

  • 递归头:什么时候不调用自身方法。如果没有头,将陷入死循环。
  • 递归体:什么时候需要调用自身方法。
public int getFactorial(int number) {

    if (number == 1) {
        return 1;
    } else {
        return number * getFactorial(number - 1);
    }

}

由于递归算法调用栈空间较多,时间复杂度相当高,因此通常在计算基数较小的时候使用递归算法。


感谢 狂神说 提供的 Java 学习资源


暂无评论

发表评论