java方法

方法

  • System.out.println();
    //System是系统的类;out是对象;println是方法
    
  • java方法是语句的集合,它们在一起执行一个功能。

    • 方法是解决一类问题的步骤的有序组合
    • 方法包含于类或对象中
    • 方法在程序中被创建,在其他地方被引用
  • 设计方法的原则:方法的本意是功能块,就是实现某个功能的语句块的集合。我们设计方法的时候,最好保持方法的原子性,就是一个方法只完成1个功能,这样利于我们后期的扩展。

方法的定义

  • java的方法类似于其它语言的函数,是一段用来完成特定功能的代码片段,一般情况下,定义一个方法包含以下语句:
  • 方法包含一个方法头和一个方法体。下面是一个方法的所有部分:
    • 修饰符:修饰符,这是可选的,告诉编译器如何调用该方法。定义了该方法的访问类型。
    • 返回值类型:方法可能会返回值。return Value Type是方法返回值的数据类型。有些方法执行所需的操作,但没有返回值。在这种情况下,return Value Type是关键字void。
    • 方法名:是方法的实际名称。方法名和参数表共同构成方法签名。
    • 参数类型:参数像一个占位符。当方法被调用时,传递值给参数。这个值被称为实参或变量。参数列表是指方法的参数类型、顺序和参数的个数。参数是可选的,方法可以不包含任何参数。
      • 形式参数:在方法被调用时用于接收外界输入的数据。是用来定义作用的。
      • 实参:调用方法时实际传给方法的数据。
      • 参数:是指进入方法的数据,有了这些数据,方法才能执行逻辑。
    • 返回值:是指从方法中出来的数据,也就是方法执行之后的最终结果数据。
    • 方法体:方法体包含具体的语句,给定该方法的功能。
    • 语法格式:
修饰符 返回值类型 方法名(参数类型 参数名){
          ...
          方法体
          ...
          return 返回值;

}
访问权限修饰符 其他修饰符 返回值类型 方法名称(参数列表) {
 //方法体【函数体】 return 返回值;
 //如果返回值类型void ,可以不用写return 
 }

  • Java访问修饰符包括private,default,protected和public。含义分别表示私有的,默认的,受保护的和公有的访问修饰符。不写默认是default

方法的调用

  • 调用方法:对象名.方法名(实参列表)
  • java支持两种调用方法的方式,根据方法是否返回值来选择。
  • 当方法返回一个值的时候,方法调用通常被当作一个值。例如:
int larger = max(30,40);
  • 如果方法返回值是void,方法调用一定是一条语句。
System.out.println("Hello,hcss!")
  • 课后拓展了解:值传递(java)和引用传递

Demo01

package 方法的定义;

import java.security.PublicKey;

public class Demo01 {
    //main方法
    public static void main(String[] args) {

        //实际参数:实际调用传递给它的参数。
        double add = add(1, 2, 3);
        System.out.println(add);

        //test();

        int xxx = xxx(5, 3);
        System.out.println(xxx);

    }

    //加法:
    //形式参数:用来定义作用的。
    public static int add(int a,int b,int c){
        return  a+b+c;
        //public是修饰符;int是方法的返回值类型;
    }

    public static void test(){
        for (int i = 0; i <= 1000; i++) {
            if (i%5==0){
                System.out.print(i+"\t");
            }
            if (i%(5*3)==0){
                System.out.println();


            }
        }
    }
    public static int xxx(int a,int b){
        int result =0;
        if(a==b){
            System.out.println("平局,重新开始");
            return 0;
        }
        if (a>b){
            System.out.println("蓝方胜");
        }else {
            System.out.println("红方胜");
        }
        return 0;
    }

}

Demo02

package 方法的定义;

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 num3);

    //public static int max(int num1,int num2);

    public static double max(double num1,double num2){

        double result = 0;

        if (num1==num2){
            System.out.println("nm1==nm2");
            return 0;//终止方法
        }

        if (num1>num2){
            result = num1;
        }else {
            result = num2;
        }

        return  result;

    }
}

方法的重载

  • 重载就是在一个类中,有相同的函数名称,但形参不同的函数。
  • 方法的重载的规则:
    • 方法名称必须相同
    • 参数列表必须不同(个数不同、或类型不同、参数排列顺序不同等)
    • 方法的返回类型可以相同也可以不同
    • 仅仅返回类型不同不足以成为方法的重载
  • 实现理论:
    • 方法名称相同时,编译器会根据调用方法的参数个数、参数类型等逐个匹配,以选择对应的方法,如果匹配失败,则编译器报错。

Demo01

package 方法的重载;

public class Demo01 {
    public static void main(String[] args) {
        int add = add(1, 2, 3);
        System.out.println(add);


    }
    //方法的重载:
    public static double add(double a,double b){
        return  a+b;
        //public是修饰符;int是方法的返回值类型;
    }
    public static int add(int a,int b,int c){
        return  a+b+c;
    }
    public static int add(int a,int b){
        return  a+b;
    }

    //参数列表必须不同(个数不同、或类型不同、参数排列顺序不同等)
}

命令行传参

  • 有时候你希望运行一个程序时再传递给它消息。这要靠传递行参数给main()函数实现。
public class CommandLine{
     public static void main(String args[]){
     for(int i=0;i<args.length;i++){
     System.out.println("args["+i+"]:"+args[i])
          }
     }
}

Demo01

package 命令行参数;

public class Demo01 {

    public static void main(String[] args) {
        //args.length:数组长度
        for (int i = 0; i < args.length; i++) {
            System.out.println("args["+i+"]:"+args[i]);//当前第i个参数的值是[i]

        }

    }
}

可变参数

  • JDK1.5开始,java支持传递同类型的可变参数给一个方法。
  • 在方法声明中,在指定参数类型后加一个省略号(...)
  • 一个方法中只能指定一个可变参数,它必须是方法的最后一个参数。任何普通的参数必须在它之前声明。
public  static void printMax(double...numbers){
        if (numbers.length==0){
            System.out.println("No argument passed");
            return;
        }
        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);

    }

Demo01

package 可变参数;

//不定项参数
public class Demo01 {
    public static void main(String[] args) {
        Demo01 demo01 = new Demo01();
        demo01.test(1,5,6,8,66);//i的第0个值是1
        demo01.tt(1,22,33,225);
    }
      //在方法声明中,在指定参数类型后加一个省略号(...)。
    public void test(int... i){//...的作用:当要传递多个i或不确定要传递多少i时,用...
        System.out.println(i[2]);//输出i的第0个值。
    }

    //一个方法中只能指定一个可变参数,它必须是方法的最后一个参数。
    public void tt(int x,int...i){
        System.out.println(i);
    }
}

Demo02

package 可变参数;

public class Demo02 {
    public static void main(String[] args) {
        //调用可变参数的方法
        printMax(34,3,3,2,56.5);
        printMax(new double[]{1,2,3,51,664});
    }

    public  static void printMax(double...numbers){
        //调用可变参数的方法
        if (numbers.length==0){//判断传递的参数为0
            System.out.println("No argument passed");
            return;
        }
        double result = numbers[0];

        //排序算法
        for (int i = 1; i < numbers.length; i++) {
            if (numbers[i] > result){//若第i个数大于result
                result = numbers[i];
            }
        }
        System.out.println("The max value is"+result);
    }
}

区别什么是类方法和实例方法

  • 类方法:又叫做静态方法,使用static修饰的方法,是属于当前整个类的,而不是属于某个实例的,只能处理static域或调用static方法。
  • 实例方法:属于对象的方法,由对象来调用。
  • 一个类中的方法可以互相调用。实例方法可以调用该类中的其他方法,但类方法只能调用其它类方法,不能调用实例方法。
  • 类方法可以直接通过类名调用,实例方法必须先初始化类的实例,然后通过类的实例才能调用。

递归

  • A方法调用B方法很容易理解

  • 递归就是:A方法调用A方法,自己调用自己

  • 利用递归可以用简单的程序来解决一些复杂的问题。递归的能力在于用有限的语句来定义对象的无限集合。

  • 递归结构包括两个部分:

    • 递归头:什么时候不调用自身方法。如果没有头,将陷入死循环。
    • 递归体:什么时候需要调用自身方法。
  • 边界条件:到最后一个数时,程序会执行到底。

  • 递归的前阶段:当参数不等于输入值时,会一直调用自身。

  • 递归三要素

    1.处理方法,方法自调来解决大规模的问题,提取相同的逻辑,缩小问题规模。

    2.明确递归的终止条件

    3.给出递归终止的解决方法

Demo01

package 递归;

import com.sun.corba.se.impl.orb.ParserTable;

public class Demo01 {
    public static void main(String[] args) {
        Demo01 test = new Demo01();
        test.test();
    }
    public void test(){
        test();
    }
}

Demo02

package 递归;

public class Demo02 {
    //举例:阶乘
    //递归思想
    public static void main(String[] args) {
        System.out.println(f(5));
    }

      //1!  1
      //2!   2*1
      //5!  5*4*3*2*1
    public static int f(int n){

        if (n==1){
            return 1;
        }else {
            return n*f(n-1);//若n==2,则2*f(1)1;若n==3,则3*f(2)
        }
    }


}

Demo03

package 递归;

import java.util.Scanner;

public class Demo03 {
    public static void main(String[] args) {
        /*题目:写一个计算器,要求实现加减乘除功能,并且能够循环接收新的数据,通过用户交互实现。
           思路推荐:
               写4个方法:加减乘除
               利用循环+switch进行用户交互
               传递需要操作的两个数
               输出结果
         */
            Scanner scanner = new Scanner(System.in);
            while (true) {
                System.out.println("请输入第一个数:");
                double a = scanner.nextDouble();
                System.out.println("请输入运算符:");
                String type = scanner.next();
                System.out.println("请输入第二个数:");
                double b = scanner.nextDouble();

                switch (type) {
                    case "+":
                        System.out.println("结果为:" + add(a, b));
                        continue;

                    case "-":
                        System.out.println("结果为:" + sub(a, b));
                        continue;

                    case "*":
                        System.out.println("结果为:" + mul(a, b));
                        continue;

                    case "/":
                        System.out.println("结果为:" + div(a, b));
                        continue;

                    default:
                        System.out.println("无效的运算符!");


                }
                scanner.close();
            }



        }
        public static double add(double a,double b){
            return a+b;
        }
        public static double sub(double a,double b){
            return a-b;
        }
        public static double mul(double a,double b){
            return a*b;
        }
        public static  double div(double a,double b){
            return a/b;
        }

    }



Demo04

package 递归;

public class Demo04 {
    //爬楼梯算法:已知一个楼梯有n个台阶,每次可以选择迈上一个或者两个台阶,求走完一共有多少种不同的走法
    public static void main(String[] args) {
        Demo04 demo04 = new Demo04();
        int a = demo04.clim(6);
        System.out.println(a);
    }
    public int clim (int n){
        int i =1;
        if (n<=0)
            return 0;
        if (n==1){
            return i;
        }
        if (n==2){
            i++;
            return  i;
        }
        else
            return clim(n-1)+clim(n-2);

    }


}


posted @ 2021-09-07 17:35  花朝十三博客  阅读(39)  评论(0)    收藏  举报