标签:Java int System println 参数 2.3 方法 public
目录
何为方法?
-
Java方法是语句的集合,他们在一起执行一个功能,类似于其他语言中的函数。
- 方法是解决一类问题的步骤的有序组合
- 方法包含于类或对象中
- 方法在程序中被创建,在其他地方被引用
-
设计方法的原则:保持原子性,一个方法只完成一个功能,利于拓展
-
命名规则(首字母小写,驼峰命名规则)
1.方法定义
-
方法包括一个方法头和一个方法体。
-
修饰符:可选,告诉编译器如何调用该方法,定义了该方法的访问类型。
-
返回值类型:方法可能会有返回值。returnValueType是方法返回值的数据类型;若没有返回值,returnValueType关键字则为void
-
方法名:方法的实际名称,方法名和参数表共同构成方法签名。
-
方法体:方法体包含具体的语句,定义该方法的功能。
-
参数类型:参数像是一个占位符。当方法被调用时,传递值参数。这个值被称为实参或者变量。
参数列表是指方法的参数类型,顺序和参数的个数。
参数是可选的,方法可以不包括任何参数。
修饰符 返回值类型 方法名(参数类型 参数名){ ... 方法体 ... return 返回值;//可以没有 }
-
package com.kuang.method;
public class Demo1 {
//main 方法,保持整洁
public static void main(String[] args) {
//实际参数:实际调用传递给他的参数值
int sum = add(1,2);
triangle();
System.out.println(sum);
}
//加法。 形式参数,用来定义用的
public static int add(int a, int b){
return a+b;
}
}
-
方法调用
对象是类的实例化
//return 可以终止方法
package com.kuang.method; import java.util.Scanner; public class Demo2_bigLittle { public static void main(String[] args) { int a = 10, b = 64; int re = compare(a, b); System.out.println(re); } //comparison public static int compare(int num1, int num2){ //返回的话需要设置初值 int result = 0; if(num1>num2) result = num1; else if(num2>num1) result = num2; else{ System.out.println("num1 == num2"); // return 有终止方法的作用 return 0; } return result; } }
2.方法的重载
-
重载就是在一个类中,有相同的函数名称,但是形参不同的函数(类型,顺序,数目)。
-
方法重载的规则:
- 方法名称必须相同
- 参数列表必须不同(类型,顺序,数目)
- 方法的返回类型可以相同也可以不同
- 仅仅返回类型不同不足以成为方法的重载。
-
实现理论:方法名称相同时,编译器会根据调用方法的参数个数,类型去逐个匹配,以找到正确的方法。
3.命令函传参
运行时再传递消息,靠命令行传递参数给main()
- java命令执行class 一定要到包src路径下,在class文件是不可以的,
4.可变参数(不定项参数)
JDK1.5之后,可以给方法传很多同类型的可变参数
- 在方法声明中,在指定参数类型后面加一个省略号(...)
- 一个方只能指定一个可变参数,且它必须为最后一个参数
ALT + ENTER 自动补全
package com.kuang.method;
public class variableFactor {
public static void main(String[] args) {
variableFactor var = new variableFactor();
var.test(1,2,3,4,5);
}
public void test (int... i){
System.out.println(i[0]);
System.out.println(i[1]);
System.out.println(i[2]);
System.out.println(i[3]);
System.out.println(i[4]);
}
}
5.递归
- 自己调用自己
- 递归结构包括
- 递归头,什么时候停止递归。如果没有头,将陷入死循环。
- 递归体,什么时候需要调用自身方法。
recurrence 递归
factorial 阶乘
package com.kuang.method;
import java.util.Scanner;
public class Factorial {
public static void main(String[] args) {
System.out.println("Write down: ");
Scanner input = new Scanner(System.in);
int output = f(input.nextInt());
System.out.println(output);
}
public static int f(int n){
if(n == 1){
return 1;
}else
return n*f(n-1);
}
}
练习:计算器,实现加减乘除,循环接受
思路:4个方法;循环+switch
标签:Java,int,System,println,参数,2.3,方法,public 来源: https://www.cnblogs.com/zlr585/p/14459787.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。