JAVA学习笔记_方法的使用

135 阅读3分钟

JAVA学习笔记_方法的使用

1.方法的概念及使用

1.1概念

方法就是一个代码片段. 类似于 C 语言中的 "函数"

  1. 是能够模块化的组织代码(当代码规模比较复杂的时候)
  2. 当代码被重复使用, 一份代码可以在多个位置使用,减少代码冗余
  3. 让代码更好理解更简单
  4. 直接调用现有方法开发, 不必重复造轮子

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);
}