方法
何为方法
-
Java方法是语句的集合,他们在一起执行一个功能
- 方法是解决一类问题的步骤的有序组合
- 方法包含于类或对象中
- 方法在程序中被创建,在其他地方被引用
-
方法的设计原则:方法的本意是功能块,就是实现某个功能的语句块的集合。
我们设计方法的时候最好保持方法的原子性,就是一个方法只完成一个功能
这样利于我们后期的扩展
-
方法的命名规则:驼峰式
两个整数的相加的方法
import java.util.Scanner;
public class Demo01 {
//main方法
public static void main(String[] args) {
Scanner scanner01 = new Scanner(System.in);
Scanner scanner02 = new Scanner(System.in);
System.out.println("请输入第一个整数:");
int N = scanner01.nextInt();
System.out.println("请输入第二个整数:");
int M = scanner02.nextInt();
int sum = add(M,N);
System.out.println("您输入的两个整数的结果是:"+"\n"+sum);
}
//加法
public static int add(int a,int b){
return a+b;
}
}
方法的定义
Java的方法类似于其它语言的函数,是一段用来完成特定功能的代码片段,一般情况下,定义一个方法包含以下语法:
方法包含一个方法头和一个方法体。下面是一个方法的所有部分:
-
修饰符:修饰符,这是可选的,告诉编译器如何调用该方法。定义了该方法的访问类型。
-
返回值类型∶方法可能会返回值。returnValueType是方法返回值的数据类型。有些方法执行所需的操作,但没有。返回值。在这种情况下,returnValueType是关键字void。
-
方法名:是方法的实际名称。方法名和参数表共同构成方法签名。
-
参数类型
:参数像是一个占位符。当方法被调用时,传递值给参数。这个值被称为实参或变量。参数列表是指方法的参数类型、顺序和参数的个数。参数是可选的,方法可以不包含任何参数。 参数类型、顺序和参数的个数。参数是可选的,方法可以不包含任何参数。
- 形式参数:在方法被调用时用于接收外界输入的数据。
- 实参:调用方法时实际传给方法的数据。
-
方法体:方法体包含具体的语句,定义该方法的功能。
修饰符 返回值类型 方法名(参数类型 参数名){ 方法体}
Java 都是直传递
方法的重载
方法的重载的规则
- 方法名称必须相同
- 参数列表必须不同(个数不同、类型不同、参数列表排序不同等)
实现理论
- 方法名称相同时,编译器会根据调用方法的参数个数、参数类型等去逐个匹配,以选择对应的方法,如果匹配失败,则编译器报错。
public class Demo03 {
public static void main(String[] args) {
int i = max(3, 30);
System.out.println(i);
}
//方法的重载 一个类里面有名字相同的方法 只是参数类型不同
public static int max(int num1, int num2) {
int result;
if (num1 == num2) {
System.out.println("两个数相等");
return 0;
}
if (num1 > num2) {
System.out.println(num1 + " 大于 " + num2);
System.out.println("较大的数为:" + num1);
result = num1;
} else {
System.out.println(num2 + " 大于 " + num1);
System.out.println("较大的数为:" + num2);
result = num2;
}
return result;
}
public static double max(double num1, double num2) {
double result = 0;
if (num1 == num2) {
System.out.println("两个数相等");
return 0;
}
if (num1 > num2) {
System.out.println(num1 + " 大于 " + num2);
System.out.println("较大的数为:" + num1);
result = num1;
} else {
System.out.println(num2 + " 大于 " + num1);
System.out.println("较大的数为:" + num2);
result = num2;
}
return result;
}
}
命令行传参
public class Demo04 {
public static void main(String[] args) {
for (int i = 0; i < args.length; i++) {
System.out.println("args["+ i +"]"+args[i]);
}
}
}
首先在 .java 文件夹下编译文件 javac Demo04.java
然后在 src 目录下执行 java cn.tigger.Method.Demo04 参数
可变参数
public class Demo05 {
public static void main(String[] args) {
printMax(33,666,6,6,66,6,6,66,6,6666,6);
printMax(new double[]{1,2,4,5,6});
}
public static void printMax( double... numbers){
if (numbers.length == 0){
System.out.println("没有传入参数!");
return;
}
double result = numbers[0];
//排序算法
for (int i = 1;i < numbers.length;i++){
if (numbers[i] > result){
result = numbers[i];
}
}
System.out.println("最大值是:"+result);
}
}
递归
- 递归结构包括两个部分
- 递归头:什么时候不调用自身方法。如果没有头,将陷入死循环
- 递归体:什么时候需要调用自身方法。