? 形式参数:在方法被调用时用于接收外界输入的数据
? 实参:调用方法实际传给方法的数据
? 5.方法体:方法体包含具体的语句,定义该方法的功能。
修饰符 返回值类型 方法名(参数类型 参数名){
....
方法体
....
return 返回值; //如果方法存在返回值的时候,一定要通过return返回出去,如果是void,无需通过return返回值
}
```
public class Demo01 {
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;
}
}
public class Demo02 {
public static void main(String[] args) {
int max = max(10,20);
System.out.println(max);
}
//比大小
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;
}
}
Java一定是一个值传递
重载就是在一个类中,有相同的函数名称,但形参不同的函数
方法重载的规则
实现理论
方法名称相同时,编译器会根据调用方法的参数个数、参数类型等去逐个匹配,以选择对应的方法,如果匹配失败,则编译器报错
public class Demo02 {
public static void main(String[] args) {
double max = max(10,20);
System.out.println(max);
}
//比大小
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 double max(double num1,double num2){
double result = 0;
if (num1 == num2){
System.out.println("num1==num2");
return 0;
}
if(num1>num2){
result = num1;
}else {
result = num2;
}
return result;
}
}
有时候你希望运行一个程序时候再传递给它消息,这要靠传递命令行参数给main()函数实现
public class CommangLine{
public static void main(String args[]){
for(int i=0;i<args.length;i++){
System.out.println("args[" + i + "]:" + args[i]);
}
}
}
A方法调用B方法,我们很容易理解
递归就是:A方法调用A方法!就是自己调用自己
利用递归可以用简单地程序来解决一些复杂的问题,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合。
递归结构包括两个部分:
递归头:什么时候不调用自身方法,如果没有头,将陷入死循环
递归体:什么时候需要调用自身方法。
public class Demo03 {
public static void main(String[] args) {
System.out.println(f(5));
}
//5! 5*4*3*2*1
public static int f(int n){
if (n==1){
return 1;
}else {
return n*f(n-1);
}
}
}
原文:https://www.cnblogs.com/xiaoyao-feng/p/14357363.html