JAVA学习笔记_方法的使用
1.方法的概念及使用
1.1概念
方法就是一个代码片段. 类似于 C 语言中的 "函数"
- 是能够模块化的组织代码(当代码规模比较复杂的时候)
- 当代码被重复使用, 一份代码可以在多个位置使用,减少代码冗余
- 让代码更好理解更简单
- 直接调用现有方法开发, 不必重复造轮子
1.2方法定义
方法格式
修饰符 返回值类型 方法名称([参数类型 形参 ...]){
方法体代码;
return 返回值;
}
注意事项:
- 返回值类型:如果方法有返回值,返回值类型必须要与返回的实体类型一致,如果没有返回值,必须写成 void
- 方法名字:采用小驼峰命名
- 参数列表:如果方法没有参数,()中什么都不写,如果有参数,需指定参数类型,多个参数之间使用逗号隔开
- 方法体:方法内部要执行的语句
- 在 java当中,方法必须写在类当中
- 在java当中,方法不能嵌套定义
1.3方法调用
定义方法时不会执行方法的代码,只有调用的时候才会执行
//计算两个整数相加
public class Method {
public static void main(String[] args){
int a = 10;
int b = 20;
ret = add(30, 50);
System.out.println("ret = " + ret);
}
public static int add(int x, int y) {
return x + y;
}
}
1.4实参和形参的关系
形参的名字可以随意 取,对方法都没有任何影响,形参只是方法在定义时需要借助的一个变量,用来保存方法在调用时传递过来的值
public static int getSum(int N){ // N是形参
return (1+N)*N / 2;
}
getSum(10); // 10是实参,在方法调用时,形参N用来保存10
getSum(100); // 100是实参,在方法调用时,形参N用来保存100
public static int add(int a, int b){
return a + b;
}
add(2, 3); // 2和3是实参,在调用时传给形参a和b
在Java中,实参的值永远都是拷贝到形参中,形参和实参本质是两个实体
1.5没有返回值的方法
方法的返回值是可选的,有些时候可以没有的,没有时返回值类型必须写成void
2.方法重载
2.1概念
在Java中,如果多个方法的名字相同,参数列表不同,则称该方法被重载.
public class TestMethod {
public static void main(String[] args) {
add(1, 2); // 调用add(int, int)
add(1.5, 2.5); // 调用add(double, double)
add(1.5, 2.5, 3.5); // 调用add(double, double, double)
}
public static int add(int x, int y) {
return x + y;
}
public static double add(double x, double y) {
return x + y;
}
public static double add(double x, double y, double z) {
return x + y + z;
}
}
方法名必须相同
参数列表必须不同(参数的个数不同、参数的类型不同、类型的次序必须不同)
与返回值类型是否相同无关
编译器在编译代码时,会对实参类型进行推演,根据推演的结果来确定调用哪个方法
2.2方法签名
在同一个作用域中不能定义两个相同名称的标识符。比如:方法中不能定义两个名字一样的变量,那为什么类中就 可以定义方法名相同的方法呢? 方法签名即:经过编译器编译修改过之后方法最终的名字。具体方式:方法全路径名+参数列表+返回值类型,构成方法完整的名字。
3.递归
3.1概念
一个方法在执行过程中调用自身, 就称为 "递归"
3.2递归练习
//按顺序打印一个数字的每一位(例如 1234 打印出 1 2 3 4)
public static void print(int num) {
if (num > 9) {
print(num / 10);
}
System.out.println(num % 10);
}
//输入一个非负整数,返回组成它的数字之和
public static int sum(int num) {
if (num < 10) {
return num;
}
return num % 10 + sum(num / 10);
}
//斐波那契数列
public static int fib(int n) {
if (n == 1 || n == 2) {
return 1;
}
return fib(n - 1) + fib(n - 2);
}