什么是方法
1.java方法是语句的集合,它们在一起执行一个功能。
2.方法是解决一类的问题的步骤的有序组合。
3.方法包含于类或对象中。
4.方法在程序中被创建,在其他地方被引用。
例如System.out.println()
System是一个类
out是一个输出对象
println()就是一个方法
public class method1 {
//main方法
public static void main(String[] args) {
//实际参数:实际调用传递给他的参数
int sum = add(1,2);
System.out.println(sum);
}
//加法
public static int add(int a,int b){
return a+b;
}
}
上面就是一个简单的方法
方法的定义
java的方法类似于其它语言的函数,就如python中定义的def(),是一段用来完成特点功能的代码片段。
方法包含一个方法头和一个方法体。下面是方法的所有部分:
- 修饰符:修饰符是可选的,告诉编译器如何调用该方法,定义了该方法的访问类型
- 返回值类型:方法可能会放回置,returnVlaueType是方法返回值的数据类型,有些方法执行所需的操作,但没有返回值。这种情况下,returnValueType是关键字void。
- 方法名:是方法的实际名称。方法名和参数表共同构成方法签名。
- 参数类型:参数是一个占位符,当方法被调用时,传递值给参数。这个值被称为实参或者变量。参数列表时之方法的参数类型,顺序和参数的个数。参数是可选的,方法可以不包含任何参数。
形式参数:在方法被调用时用于接收外界输入的数据
实际参数:调用方法是实际传给方法的数据
5. 方法体:方法体包含具体的语句,定义该方法的功能。
方法的重载
重载就是在一个类中,有相同的函数名称,但形参不同的函数。
方法重载的规则:
- 方法名称必须相同
- 参数列表必须不同(个数不同,类型不同,或者是参数排列顺序不同)
- 方法的返回类型可以相同也可以不同
- 仅仅返回类型不同不足以成为方法的重载
public class method2 {
public static void main(String[] args) {
double n = max(3,3,4);
System.out.println(n);
}
//比较大小
public static int max(int num1,int num2){
return Math.max(num1, num2);
}
//
public static double max(double num1,double num2,double num3) {
return Math.max(num1, num2);
}
}
上述代码就是一个参数类型和个数不同的方法重载。
命令行传参
我也学的不深,简单示范一下。
public class method3_commandLineParameter {
public static void main(String[] args) {
for (int i = 0; i < args.length; i++) {
System.out.println("arg["+i+"]:"+args[i]);
}
}
}
找到命令行模式
进入你所在的文件目录
按照自己的名称输入 javac name.java
然后需要返回src目录
使用java命令 后面跟着包的名字要一致
可以看的没有输出,我们后面可以加一些参数
这样就是最后结果了
也可以进入cmd,执行。
可变参数
方法为在参数类型中加一个省略号(…)
并且一个方法中只能指定一个可变参数,他必须是方法的最后一个参数。任何普通参数必须在他之前声明。
注:JDK1.5开始,java才支持传递同类型的可变参数给一个方法。
public class method4_variadicParameters {
public static void main(String[] args) {
//调用可变参数的方法
printMax(32,21,123,12,21);
printMax(new double[]{1,2,3,9.9});
}
public static void printMax(double... numbers){
if (numbers.length==0){
System.out.println("no arguments passed");
}
double result = numbers[0];
for (int i =1;i< numbers.length;i++){
if (numbers[i]>result){
result = numbers[i];
}
}
System.out.println("the numbers max is" + result);
}
通过一个简单的排序代码,了解一下可变参数。
递归
递归通俗来讲自己调用自己。
递归结构包括两个部分:
1. 递归头:什么时候不调用自身方法。如果没有头,将陷入死循环。
2. 递归体:什么时候需要调用自身方法。
说到递归,就不得不说到阶乘了。
下面使用阶乘来演示一下递归的方法。
public class method5Recursion {
public static void main(String[] args) {
System.out.println(f(10));
}
public static int f(int n){
if (n==1){
return 1;
}else {
return n*f(n-1);
}
}
}
如果嵌套层次比较深得算法,递归就不适用了。可能会造成内存崩溃。上述阶乘当求到31时就是极限了。后面会输出为0.大计算尽量避免递归方法。