当前位置:   article > 正文

Java_方法(重载方法签名等详解)

Java_方法(重载方法签名等详解)

在之前我们学习C语言时,当我们想要重复使用某段代码的功能时,我们会将这段代码定义为一个函数,而在java中我们把这段重复使用的代码叫做方法。

方法的定义

类体的内容分为变量的声明和方法的定义,方法的定义包括两部分:方法头和方法体。

// 方法定义
修饰符 返回值类型 方法名称 ([ 参数类型 形参 ...]){
方法体代码 ;
[ return 返回值 ];
}
举个例子:检验一个年份是否为闰年
  1. public class Method{
  2. public static boolean LeapYear(int year){
  3. if((year%4==0&&year%100!=0)||year%400==0)){
  4. return true;
  5. }
  6. else{
  7. return false;
  8. }
  9. }
  10. }
注意事项
1. 修饰符:现阶段直接使用 public static 固定搭配
2. 返回值类型:如果方法有返回值,返回值类型必须要与返回的实体类型一致,如果没有返回值,必须写成
void
3. 方法名字:采用小驼峰命名
4. 参数列表:如果方法没有参数, () 中什么都不写,如果有参数,需指定参数类型,多个参数之间使用逗号隔开
5. 方法体:方法内部要执行的语句
6. java 当中,方法必须写在类当中
7. java 当中,方法不能嵌套定义
8. 在java当中,没有方法声明一说,java是在全局搜索的,这点与c语言不一样哦。

方法调用的执行过程

方法调用过程

      调用方法 --- > 传递参数 --- > 找到方法地址 --- > 执行被调方法的方法体 --- > 被调方法结束返回 --- > 回到主调方法继续往下 执行。

这里在给大家一个例子好好体会一下java方法的语法:

计算1到5的阶乘:

  1. public class TestMethod {
  2. public static void main(String[] args) {
  3. int sum = 0;
  4. for (int i = 1; i <= 5; i++) {
  5. sum += fac(i);
  6. }
  7. System.out.println("sum = " + sum);
  8. }
  9. public static int fac(int n) {
  10. System.out.println("计算 n 的阶乘中n! = " + n);
  11. int result = 1;
  12. for (int i = 1; i <= n; i++) {
  13. result *= i;
  14. }
  15. return result;
  16. }
  17. }
  1. // 执行结果
  2. 计算 n 的阶乘中 n! = 1
  3. 计算 n 的阶乘中 n! = 2
  4. 计算 n 的阶乘中 n! = 3
  5. 计算 n 的阶乘中 n! = 4
  6. 计算 n 的阶乘中 n! = 5
  7. sum = 153

java方法中形参与实参的关系

这里需要着重给大家强调,在java中所有的方法里形参都是实参的一份临时拷贝,这里与C语言是一样的。

还是给大家列举一个交换数值的例子帮助理解:

  1. public class TestMethod {
  2. public static void main(String[] args) {
  3. int a = 10;
  4. int b = 20;
  5. swap(a, b);
  6. System.out.println("main: a = " + a + " b = " + b);
  7. }
  8. public static void swap(int x, int y) {
  9. int tmp = x;
  10. x = y;
  11. y = tmp;
  12. System.out.println("swap: x = " + x + " y = " + y);
  13. }
  14. }
  15. // 运行结果
  16. swap: x = 20 y = 10
  17. main: a = 10 b = 20

我们发现a与b的值并没有因为经过swap而发生交换,交换的只不过是形参x,y而实参a,b并没有改变。

注意:对于基础类型来说, 形参相当于实参的拷贝. 传值调用

方法重载

功能多态性就是指可以向功能传递不同的消息,以便让对象根据相应的消息来产生相应的行为。对象的行为通过类中的方法来体现,那么行为的多态性就是方法的重载。

简单点来说的话就是:

一个词语如果有多重含义,那么就说该词语被重载了,具体代表什么含义需要结合具体的场景。
Java 中方法也是可以重载的。
Java 中,如果多个方法的名字相同,参数列表不同,则称该几种方法被重载了。
  1. public class TestMethod {
  2. public static void main(String[] args) {
  3. int a = 10;
  4. int b = 20;
  5. int ret = add(a, b);
  6. System.out.println("ret = " + ret);
  7. double a2 = 10.5;
  8. double b2 = 20.5;
  9. double ret2 = add(a2, b2);
  10. System.out.println("ret2 = " + ret2);
  11. }
  12. public static int add(int x, int y) {
  13. return x + y;
  14. }
  15. }

add函数只能是完成两个整形的相加,而如果你若需要其他数据类型数据完成相加这个功能时还得,重新写一个方法,这就显得很多余,所以,java给我们提供了方法的重载。

注意:想要函数重载,你得满足一下几个要求

1. 方法名必须相同
2. 参数列表必须不同(参数的个数不同、参数的类型不同、类型的次序必须不同)
3. 与返回值类型是否相同无关 

还是举个例子帮助理解:

  1. public class TestMethod {
  2. public static void main(String[] args) {
  3. add(1, 2); // 调用add(int, int)
  4. add(1.5, 2.5); // 调用add(double, double)
  5. add(1.5, 2.5, 3.5); // 调用add(double, double, double)
  6. }
  7. public static int add(int x, int y) {
  8. return x + y;
  9. }
  10. public static double add(double x, double y) {
  11. return x + y;
  12. }
  13. public static double add(double x, double y, double z) {
  14. return x + y + z;
  15. }
  16. }

 方法签名

在同一个作用域中不能定义两个相同名称的标识符。比如:方法中不能定义两个名字一样的变量,那 为什么类中就
可以定义方法名相同的方法呢?
方法签名即:经过编译器编译修改过之后方法最终的名字。具体方式: 方法全路径名 + 参数列表 + 返回值类型,构成
方法完整的名字。

这就是方法重载这个概念建立的基础。 

  1. public class TestMethod {
  2. public static int add(int x, int y){
  3. return x + y;
  4. }
  5. public static double add(double x, double y){
  6. return x + y;
  7. }
  8. public static void main(String[] args) {
  9. add(1,2);
  10. add(1.5, 2.5);
  11. }
  12. }

Java递归

从前有坐山,山上有座庙,庙里有个老和尚给小和尚将故事,讲的就是:
" 从前有座山,山上有座庙,庙里有个老和尚给小和尚讲故事,讲的就是:
" 从前有座山,山上有座庙 ..."
" 从前有座山 ……"

这小段话完美诠释了递归的思想,就是在方法中调用自己的行为。 

递归的必要条件:
1. 将原问题划分成其子问题,注意:子问题必须要与原问题的解法相同
2. 递归出口

这里利用递归求一下n的阶乘

  1. public class Main {
  2. public static int factor(int n){
  3. if(n==0){
  4. return 1;
  5. }
  6. else{
  7. return n*factor(n-1);
  8. }
  9. }
  10. public static void main(String[] args) {
  11. int n=5;
  12. int ret=factor(n);
  13. System.out.println(ret);
  14. }
  15. }

 递归执行过程分析

这里要强调的是递归写出来的代码,对比其他的代码往往比较简洁清晰,但是我们知道,方法调用结束时才会释放它在内存中的数据,而递归他会在每一次递归的过程时产生一个新的方法的调用,这样会给内存很大负担,影响运行效率。 

递归练习

这里给大家几道递归的题,让大家体会一下递归的快乐:

按顺序打印一个数字的每一位 ( 例如 1234 打印出 1 2 3 4):
  1. public static void print(int num) {
  2. if (num > 9) {
  3. print(num / 10);
  4. }
  5. System.out.println(num % 10);
  6. }
递归求 1 + 2 + 3 + ... + 10
  1. public static int sum(int num) {
  2. if (num == 1) {
  3. return 1;
  4. }
  5. return num + sum(num - 1);
  6. }
写一个递归方法,输入一个非负整数,返回组成它的数字之和 . 例如,输入 1729, 则应该返回
1+7+2+9 ,它的和是 19
  1. public static int sum(int num) {
  2. if (num < 10) {
  3. return num;
  4. }
  5. return num % 10 + sum(num / 10);
  6. }

利用递归的方法写一个求斐波那契数列的程序

  1. public static int fib(int n) {
  2. if (n == 1 || n == 2) {
  3. return 1;
  4. }
  5. return fib(n - 1) + fib(n - 2);
  6. }

       好了,这就是java中的方法的一些基础知识了,大家可以对比C语言中的函数进行对比记忆,如果有问题的话大家直接私信我,或者评论区留言,看到就会解答哦~

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/凡人多烦事01/article/detail/133237
推荐阅读
相关标签
  

闽ICP备14008679号