Java方法的详解和使用

时间:2024-03-23 18:28:46

1.什么是方法

  方法就是一个代码片段,类似于C语言中的”函数“,它的作用为:

  1. 能够模块化地组织代码
  2. 能做到代码的重复使用,一份代码可以在多个位置使用
  3. 让代码更好理解
  4. 直接调用现有方法开发,效率更高

2.方法的定义

  语法格式:

修饰符 返回值类型 方法名称([参数类型 形参……]) {

        方法体代码;

        [return 返回值]

}

示例:用方法来实现两个数字的相加

public class Method {
    public class int add(int x,int y) {
        return x+y;
    }
}

注意事项:

  1. 修饰符:一般用public static修饰
  2. 返回值类型:如果方法有返回值,返回值类型必须要与返回的实体类型一致,如果没有返回值,必须写成void
  3. 方法名字:采用小驼峰命名
  4. 参数列表:如果方法没有参数,()中什么都不用写,如果有参数,需指定参数类型,多个参数之间使用逗号隔开
  5. 方法体:方法内要执行的语句
  6. 在Java中,方法必须写在类当中
  7. 在Java中,方法不能嵌套定义
  8. 在Java中,没有方法声明的说法

2.形参和实参的关系

方法的形参相当于函数中的自变量,比如:

Java中方法形参就相当于sum函数中的自变量n,用来接收sum函数在调用时传递的值的。形参的名字可以随意取,对方法都没有任何影响,形参只是方法定义时需要借助的一个变量,用来保存方法在调用时传递过来的值。

示例:

public static int sum(int n) {

        return (1+n)*n/2;

}

sum(10);            //10是实参,在方法调用时,形参n用来保存10

sum(1000);        //1000是实参,在方法调用时,形参n用来保存1000

注意:在Java中,实参的值永远都是拷贝到实参中的,形参和实参本质是两个实体

示例:

public class test {
    public static void main(String[] args) {
        int a=3;
        int b=5;
        swap(a,b);
        System.out.println("a="+a+"b="+b);
    }
}
public static void swap(int x,int y) {
    int tmp=x;
    x=y;
    y=tmp;
    System.out.println("x="+x"y="+y);
    }
}

 运行结果:

x=5 y=3

a=3 b=5

从运行结果可以看到,在swap函数交换后,形参x和y的值发生了变化,但是main方法中的a和b还是交换之前的值,没有交换成功。

原因:实参a和b是main方法中的两个变量,其空间方法的栈(一些特殊的内存空间)中,而形参x和y是swap方法中的两个变量,x和y的空间在swap方法运行时的栈中,因此:实参a和b与形参x和y是两个没有任何关联性的变量,在swap方法调用时,只是将实参a和b中的值拷贝了一份传递给了形参x和y,因此对形参x和y操作不会对实参a和b产生任何影响。

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

3.方法重载

概念:在Java中,如果多个方法名字相同,参数列表不同,则称该几种方法重载了。

先来看这样一段代码

public class test {
    public static void main(String[] args) {
        add(3,2);         //调用add(int,int)
        add(3.3,2.2);     //调用add(double,double)
        add(3.3,2.2,1.1); //调用add(double,double,double)
    }
    public static int add(int x,int y) {
        return x+y;
    }
    public static double add(doube x,double y) {
        return x+y;
    }
    public static double add(double x,double y,double z) {
        return x+y+y;
    }
}

需要注意的是:

1.方法名必须相同

2.参数列表必须不同(参数的个数不同,参数的类型不同,类型次序必须不同)

3.与返回值类型是否相同无关

4.方法签名

在同一个作用域中不能定义两个相同名称的标识符。比如:方法中不能定义两个名字一样的变量,那为什么类中就可以定义方法名相同的方法呢?

这里就要引入另外一个概念了即:方法签名。其概念为:经过编译器编译修改之后方法最终的名字。具体方式:方法全路径名+参数列表+返回值类型,构成方法的完整名字。

我们先来看一段代码

public class test {
    public static int add(int x,int y) {
        return x+y;
    }
    public static double add(double x,double y) {
        return x+y;
    }
    public static void main(String[] args) {
        add(3,5);
        add(3.3,5.5);
    }
}

上述代码经过编译后,我们可以使用JDK自带的javap反汇编工具查看,具体操作为:

1.先对工程进行编译生成.class字节码文件

2.在控制台中进入到要查看的.class所在的目录

3.输入:javap-v字节码文件名字即可

方法签名中的一些特殊说明: