什么是方法
-
System.out.println
类.对象.方法
-
java方法的语句的集合,它们在一起执行一个功能。
- 方法是解决一类问题的步骤的有序组合
- 方法包含于类或对象中
- 方法在程序中被创造,在其他地方被引用
-
方法设计的原则:方法的本意是功能块,就是实现某个功能的语句块的集合。最好保持方法的原子性,一个方法只完成一个功能,利于后期的扩展
public class Demo01 {
//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;
}
}
//将之前的函数用为方法在main里调用
public class Demo01 {
//main方法
public static void main(String[] args) {
// int sum= add(1,2);
//System.out.println(sum);
a();
}
//加法
public static int add(int a, int b){
return a+b;
}
public static void a(){
for (int i=0;i<1000;i++){
if(i%5==0) {
System.out.print(i+" ");
}
if(i%(5*3)==0){
System.out.print("\n");
}
}
}
}
方法的定义和调用
- java的方法类似于其他语言的函数,是一段用来完成特定功能的代码片段
-
方法包含一个方法头和一个方法体
-
修饰符:可选的,告诉编译器如何调用该方法。定义了该方法的访问类型
-
返回值类型:可能会返回值,returnValueType是方法返回值的数据类型。有些方法所需的操作,但没有返回值(void)。也叫终止方法
-
方法名:是方法的实际名称。方法名和参数表共同构成方法签名
-
参数类型:是一个占位符。当方法被调用时,传递参数。这个值被称为实参或变量。参数列表是指方法的参数类型、顺序、和参数的个数。参数是可选的,方法可以不包含任何参数。
- 形式参数:在方法被调用时用于接受外界输入的数据
- 实参:调用方法时实际长欸方法的参数
-
方法体:包含具体的语句,定义该方法的功能
-
语法
修饰符 返回值类型 方法名(参数类型 参数名){
…
方法体
…
return 返回值;
}
-
-
调用方法
-
调用方法:对象名.方法名(实参列表)
-
java支持两种调用方法的方式,根据方法是否返回值来选择
-
当方法返回值时void,方法调用一定时一条语句
System.out.println(“阿娆要努力呀”);
-
当方法返回一个值时,方法调用通常被当作一个值
int larger = max(1,2);
-
-
值传参 引用传递
[值传参 引用传递]((20条消息) 为什么说Java中只有值传递_程序员小灰的博客-CSDN博客_java值传递)
方法的重载
-
重载就是在一个类中,有相同的函数名称,但形式参数不同的函数
-
方法的重载的规则:
- 方法名必须相同
- 参数列表必须不同(个数、类型、参数排列顺序不同等)
- 方法的返回类型可以相同也可以不同
- 仅仅返回类型不同不足以成为方法的重载
-
实现理论
- 方法名称相同时,编译器会根据调用方法的参数个数、参数类型、等去逐个匹配,以选择对应方法,如果匹配失败,则编译器报错
命令行传递参数
public static void main(String args[]) 这一般是写main这个类最常写的一句话,但是其实一直不知道那个String args[]写来是干什么的。但是今天就恰好用上了。
首先,贴一个代码,
//Determine if the args[] is empty
if (args.length == 0)
{
System.out.println(“There were no commandline arguments passed!”);
}
else
{
// read the data
double length = Double.parseDouble(args[0]);
double width = Double.parseDouble(args[1]);
// Calculate the area of a rectangle
double area = length * width;
// Calculate the perimeter of a rectangle
double perimeter = 2 * (width + length);
// Calculate the diagonal of a rectangle
double diagonal = Math.sqrt(length * length + width * width);
System.out.println("The area of this rectangle is " + area);
System.out.println("The perimeter of this rectangle is " + perimeter);
System.out.println("The diagonal of this rectangle is " + diagonal);
}
如果使用scanner是这样的:
Scanner input = new Scanner(System.in);
// read the data
System.out.println("input the length of a rectangle");
double length = input.nextDouble(); //read length
System.out.println("input the width of a rectangle");
double width = input.nextDouble(); //read width
主要说下如何使用这个args【】,首先他是一个string 的数组,通过先人为的一次性输入他的值,然后通过解析给之后我们coding中的变量,比如,我上段代码种的double length = Double.parseDouble(args[0]);,就是读取args[0]的第一个值,解析为double类型给变量length。
原文链接:https://blog.csdn.net/qq_36098284/article/details/99654903
可变参数 不规定参数类型个数
重载写很多次
- jdk1.5开始,java支持传递同类型的可变参数给一个方法
- 在方法声明中,在指定参数类型后加一个省略号(…)
- 在一个方法只能指定一个可变参数,它必须是方法的最后一个参数。任何普通的参数必须在它之前声明···~~~
public class Demo02 {
public static void main(String[] args) {
Demo02 demo02 =new Demo02();
demo02.printMax(1,2,4,5,6,7);
demo02.printMax(new double[]{1,2,3,5,8,9,40});
}
public static void printMax(double...number){
if (number.length==0){
System.out.println("无");
return;
}
double result = number[0];
//排序
for (int i=1;i<number.length;i++){
if(number[i]>result){
result=number[i];
}
}
}
}
递归
重难点
- A方法调用B方法,
- 递归就是A方法调用A方法
- 利用递归可以用简单的程序来解决一些复杂的问题。它通常把一个复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合
- 递归的两个部分
- 递归头:什么时候不调用自身方法。如果没有头,将陷入死循环
- 递归体:什么时候需要调用自身方法
public class Demo03 {
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);
}
}
}
作业
import java.util.Scanner;
//输入时中间需要用空格隔开
public class Demo04 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
double result = scanner.nextDouble();
compute(scanner,result);
}
public static void compute(Scanner scanner,double result){
if(scanner.hasNext()){
String opr = scanner.next();
double num = scanner.nextDouble();
switch (opr){
case "+":
result += num;
break;
case "-":
result -= num;
break;
case "*":
result *= num;
break;
case "/":
result /= num;
break;
}
System.out.println(result);
compute(scanner,result);
}
}
}