①
源代码:
/*
1、Java方法是语句的集合,它们在一起执行一个功能
①方法是解决一类问题的步骤的有序组合
②方法包含于类或对象中
③方法在程序中被创建,在其他地方被引用
2、设计方法的原则:方法的本意是功能块,就是实现某个功能的语句块的集合。
我们设计方法的时候,最好保持方法的原子性,就是一个方法只完成一个功能,这样利于我们后期的扩展。
*/
public class Demo1 {
//main方法
public static void main(String[] args) {
int sum= add(3,4);
System.out.println(sum);
int max=max(5,5);
System.out.println(max);
}
//丛属于类的加法
public static int add(int a,int b){
return a+b;
}
//丛属于类的比大小的类①
public static int max(int num1,int num2) {
int result = 0;
if (num1 == num2) {
System.out.println("num1=num2");
return 0;
}
if (num1 > num2) {
result=num1;
}else{
result=num2;
}
return result;
}
}
运行结果:
7
num1=num2
0
②
源代码:
package cn.ecut.method;
/*
方法的重载:
①方法名称必须相同
②参数列表必须不同(个数不同、或类型不同、参数排列顺序不同等)
③方法的返回类型可以相同也可以不同
④仅仅返回类型不同不足以成为方法的重载
*/
public class Demo2 {
public static void main(String[] args) {
int max1=max(4,8);
int max2=max(4,8,9);
double max3=max(5.2,5.6);
System.out.println(max1);
System.out.println(max2);
System.out.println(max3);
}
public static int max(int num1,int num2){
int result = 0;
if (num1 == num2) {
System.out.println("num1=num2");
return 0;
}
if (num1 > num2) {
result=num1;
}else{
result=num2;
}
return result;
}
public static int max(int num1,int num2,int num3){
int result=0;
if(num1==num2&&num2==num3){
System.out.println("num1=num2=num3");
}
if(num1>num2&&num1>num3){
result=num1;
}
if(num2>num1&&num2>num3){
result=num2;
}
if(num3>num2&&num3>num1){
result=num3;
}
return result;
}
public static double max(double num1,double num2){
double result=0;
if(num1==num2){
System.out.println("num1=num2");
}
if(num1>num2){
result=num1;
}
if(num1<num2){
result=num2;
}
return result;
}
}
运行结果:
8
9
5.6
③
源程序:
package cn.ecut.method;
/*
①JDK1.5开始,Java支持传递同类型的可变参数给一个方法
②在方法声明中在,在指定参数类型后加一个省略号(...)。
③一个方法中只能指定一个可变参数,它必须是方法的最后一个参数。任何普通的参数必须在它之前声明。
*/
public class Demo4 {
public static void main(String[] args) {
printMax(4,8,8.2,9,9.2);
printMax(new double[]{1,2,3});
}
public static void printMax(double... numbers){
if(numbers.length==0){
System.out.println("No argument passed");
}
double result=numbers[0];
//排序
for (int i = 1; i < numbers.length ; i++) {
if(numbers[i]>result){
result=numbers[i];
}
}
System.out.println("The max value is "+ result);
}
}
运行结果:
The max value is 9.2
The max value is 3.0
④
源代码:
package cn.ecut.method;
/*
递归结构包括两个部分:
①递归头:什么时候不调用自身方法。如果没有头,将陷入死循环。
②递归体:什么时候需要调用自身方法
*/
public class Demo5 {
public static void main(String[] args) {
System.out.println(f(4));
}
public static int f(int n){
if(n==1){
return 1;
}else{
return n*f(n-1);
}
}
}
运行结果:
24