第 3章 方法
3.1 定义方法
3.2 调用方法
3.3 参数传递
3.4 递归
3.5 方法重载
3.6 习题
3.1 定义方法返回值类型 方法名(形式参数表)
{
方法体
}
Java语言中的方法与其他语言中的函数或过程类似。它用于实现类的行为,只能作为类的一部分存在。
3.1 定义方法(续)
i n t a r e a ( i n t a,i n t b )
{
r e t u r n a * b ;
}
返回值类型 方法名 形式参数返回值方法体方法头
3.1 定义方法(续)
return语句的一般使用方式如下:
return 表达式;
其作用是首先计算出表达式的值,并返回这个值,然后结束该方法的执行。
如果某个方法没有返回值,return语句就可有可无。
如果没有 return语句,该方法在被调用时,执行方法的最后一条语句后,就自动结束方法的执行。如果有
return语句,这时,return语句应表示为:
return;
一个方法中允许出现多个 return语句,分别用于不同条件下的方法返回。
3.2 调用方法
方法调用的一般形式如下:
方法名(实际参数表)
方法调用是一个表达式,其中的括号是方法调用运算符。表达式的值是被调用方法的返回值,它的类型就是方法定义中指定的方法返回值的类型。
例 3-3 调用方法源代码 运 行
3.3 参数传递
是指实参与形参的结合过程。
按值传递时,系统首先为被调用方法的形参分配内存空间,并将实参的值按位置一一对应复制给形参,此后,
被调用方法中形参值的任何改变都不会影响到实参。
例 3-4 传值调用源代码 运 行
3.4 递归
递归过程分两个阶段:
– 第 1个阶段为“递推”。
4!=4*3! 3!=3*2! 2!=2*1! 1!=1*0! 0!=1(已知 )
– 第 2个阶段为“回归”。
0!=1(已知 ) 1!=1*0!=1 2!=2*1!=2 3!=3*2!=6 4!=4*3!=24
例 3-5 用递归方法求 Fibonacci数列的第 n项
Fibonacci数列的定义为:
时当时当时当
2)2()1(
21
11
)(
nnFnF
n
n
nF
源代码 运 行
3.4 递归(续)
使用递归调用编写的程序简洁清晰,容易理解。
不过,时间和空间的开销比较大,有时甚至会引起栈溢出。
例 3-6 Hanoi塔问题的求解有三根针,设为 A,B,C。 A针上从大到小套着大小互不相等 n个金片,大的在下,小的在上。要求把这 n个金片从 A针移到 C针,在移动过程中只能借助 B针,每次只允许移动一个金片,同时要求无论在哪根针上都只允许小的金片压在大的上面。
源代码 运 行
3.5 方法重载
是指建立多个同名的方法,但方法的形参表互不相同 。
调用方法时,Java系统优先选择与实参完全匹配的方法,如果找不到完全匹配者,就进行自动类型转换以使实参与形参匹配 。
例 3-7 方法重载源代码 运 行
3.5 方法重载(续)
重载方法的返回类型可以相同,也可以不同。但如果仅仅是返 回类型不同,而方法名和形参表都相同,则是非法的。
例:
class A
{
static int f(int a)
{
return 1;
}
static double f(int a)
{
return 1.0;
}
public static void main(String[] args)
{
f(1); //无法判断调用哪个方法
}
}
3.6 习 题
3.1 定义方法
3.2 调用方法
3.3 参数传递
3.4 递归
3.5 方法重载
3.6 习题
3.1 定义方法返回值类型 方法名(形式参数表)
{
方法体
}
Java语言中的方法与其他语言中的函数或过程类似。它用于实现类的行为,只能作为类的一部分存在。
3.1 定义方法(续)
i n t a r e a ( i n t a,i n t b )
{
r e t u r n a * b ;
}
返回值类型 方法名 形式参数返回值方法体方法头
3.1 定义方法(续)
return语句的一般使用方式如下:
return 表达式;
其作用是首先计算出表达式的值,并返回这个值,然后结束该方法的执行。
如果某个方法没有返回值,return语句就可有可无。
如果没有 return语句,该方法在被调用时,执行方法的最后一条语句后,就自动结束方法的执行。如果有
return语句,这时,return语句应表示为:
return;
一个方法中允许出现多个 return语句,分别用于不同条件下的方法返回。
3.2 调用方法
方法调用的一般形式如下:
方法名(实际参数表)
方法调用是一个表达式,其中的括号是方法调用运算符。表达式的值是被调用方法的返回值,它的类型就是方法定义中指定的方法返回值的类型。
例 3-3 调用方法源代码 运 行
3.3 参数传递
是指实参与形参的结合过程。
按值传递时,系统首先为被调用方法的形参分配内存空间,并将实参的值按位置一一对应复制给形参,此后,
被调用方法中形参值的任何改变都不会影响到实参。
例 3-4 传值调用源代码 运 行
3.4 递归
递归过程分两个阶段:
– 第 1个阶段为“递推”。
4!=4*3! 3!=3*2! 2!=2*1! 1!=1*0! 0!=1(已知 )
– 第 2个阶段为“回归”。
0!=1(已知 ) 1!=1*0!=1 2!=2*1!=2 3!=3*2!=6 4!=4*3!=24
例 3-5 用递归方法求 Fibonacci数列的第 n项
Fibonacci数列的定义为:
时当时当时当
2)2()1(
21
11
)(
nnFnF
n
n
nF
源代码 运 行
3.4 递归(续)
使用递归调用编写的程序简洁清晰,容易理解。
不过,时间和空间的开销比较大,有时甚至会引起栈溢出。
例 3-6 Hanoi塔问题的求解有三根针,设为 A,B,C。 A针上从大到小套着大小互不相等 n个金片,大的在下,小的在上。要求把这 n个金片从 A针移到 C针,在移动过程中只能借助 B针,每次只允许移动一个金片,同时要求无论在哪根针上都只允许小的金片压在大的上面。
源代码 运 行
3.5 方法重载
是指建立多个同名的方法,但方法的形参表互不相同 。
调用方法时,Java系统优先选择与实参完全匹配的方法,如果找不到完全匹配者,就进行自动类型转换以使实参与形参匹配 。
例 3-7 方法重载源代码 运 行
3.5 方法重载(续)
重载方法的返回类型可以相同,也可以不同。但如果仅仅是返 回类型不同,而方法名和形参表都相同,则是非法的。
例:
class A
{
static int f(int a)
{
return 1;
}
static double f(int a)
{
return 1.0;
}
public static void main(String[] args)
{
f(1); //无法判断调用哪个方法
}
}
3.6 习 题