5.1 方法的注意事项

方法不能嵌套定义

    示例代码:

        public class MethodDemo {
            public static void main(String[] args) {
        
            }
        
            public static void methodOne() {
                public static void methodTwo() {
                    // 这里会引发编译错误!!!
                }
            }
        }

void表示无返回值,可以省略return,也可以单独的书写return,后面不加数据

    示例代码:

        public class MethodDemo {
            public static void main(String[] args) {
        
            }
            public static void methodTwo() {
                //return 100; 编译错误,因为没有具体返回值类型
                return; 
                //System.out.println(100); return语句后面不能跟数据或代码
            }
        }

5.2 方法的通用格式

格式:

    public static 返回值类型 方法名(参数) {
       方法体; 
       return 数据 ;
    }

解释:

    public static 修饰符,目前先记住这个格式

    返回值类型 方法操作完毕之后返回的数据的数据类型

    如果方法操作完毕,没有数据返回,这里写void,而且方法体中一般不写return

    方法名 调用方法时候使用的标识

    参数 由数据类型和变量名组成,多个参数之间用逗号隔开

    方法体 完成功能的代码块

    return 如果方法操作完毕,有数据返回,用于把数据返回给调用者

定义方法时,要做到两个明确

    明确返回值类型:主要是明确方法操作完毕之后是否有数据返回,如果没有,写void;如果有,写对应的数据类型

    明确参数:主要是明确参数的类型和数量

调用方法时的注意:

    void类型的方法,直接调用即可

    非void类型的方法,推荐用变量接收调用
  1. 方法重载 6.1 方法重载
    方法重载概念
    方法重载指同一个类中定义的多个方法之间的关系,满足下列条件的多个方法相互构成重载
多个方法在同一个类中

 多个方法具有相同的方法名

 多个方法的参数不相同,类型不同或者数量不同

注意:

重载仅对应方法的定义,与方法的调用无关,调用方式参照标准格式

 重载仅针对同一个类中方法的名称与参数进行识别,与返回值无关,换句话说不能通过返回值来判定两个方法是否相互构成重载

正确范例:

public class MethodDemo {
     public static void fn(int a) {
         //方法体
     }
     public static int fn(double a) {
         //方法体
     }
 }
 
 public class MethodDemo {
     public static float fn(int a) {
         //方法体
     }
     public static int fn(int a , int b) {
         //方法体
     }
 }

错误范例:

public class MethodDemo {
     public static void fn(int a) {
         //方法体
     }
     public static int fn(int a) {   /*错误原因:重载与返回值无关*/
         //方法体
     }
 }
 
 public class MethodDemo01 {
     public static void fn(int a) {
         //方法体
     }
 } 
 public class MethodDemo02 {
     public static int fn(double a) { /*错误原因:这是两个类的两个fn方法*/
         //方法体
     }
 }

6.2 方法重载练习

需求:使用方法重载的思想,设计比较两个整数是否相同的方法,兼容全整数类型(byte,short,int,long)

思路:

    ①定义比较两个数字的是否相同的方法compare()方法,参数选择两个int型参数

    ②定义对应的重载方法,变更对应的参数类型,参数变更为两个long型参数

    ③定义所有的重载方法,两个byte类型与两个short类型参数

    ④完成方法的调用,测试运行结果

代码:

    public class MethodTest {
        public static void main(String[] args) {
            //调用方法
            System.out.println(compare(10, 20));
            System.out.println(compare((byte) 10, (byte) 20));
            System.out.println(compare((short) 10, (short) 20));
            System.out.println(compare(10L, 20L));
        }
    
        //int
        public static boolean compare(int a, int b) {
            System.out.println("int");
            return a == b;
        }
    
        //byte
        public static boolean compare(byte a, byte b) {
            System.out.println("byte");
            return a == b;
        }
    
        //short
        public static boolean compare(short a, short b) {
            System.out.println("short");
            return a == b;
        }
    
        //long
        public static boolean compare(long a, long b) {
            System.out.println("long");
            return a == b;
        }
    
    }

7.3 数组遍历

需求:设计一个方法用于数组遍历,要求遍历的结果是在一行上的。例如:[11, 22, 33, 44, 55]

思路:

    ①因为要求结果在一行上输出,所以这里需要在学习一个新的输出语句System.out.print(“内容”);

    System.out.println(“内容”); 输出内容并换行

    System.out.print(“内容”); 输出内容不换行

    System.out.println(); 起到换行的作用

    ②定义一个数组,用静态初始化完成数组元素初始化

    ③定义一个方法,用数组遍历通用格式对数组进行遍历

    ④用新的输出语句修改遍历操作

    ⑤调用遍历方法

代码:

    public class Test1 {
        public static void main(String[] args) {
          /*  //先打印数据,再进行换行
            System.out.println("aaa");
            //只打印不换行
            System.out.print("bbb");
            System.out.print("ddd");
            //不打印任何内容,只换行
            System.out.println();
            System.out.print("cc");*/
            //设计一个方法用于数组遍历,要求遍历的结果是在一行上的。例如:[11, 22, 33, 44, 55]
            int[] arr = {1,2,3,4,5};
            printArr(arr);
        }
        //1.我要遍历数组
        //2.需要什么?  数组
        //3.调用处是否需要使用方法的结果。
        public static void printArr(int[] arr){
            System.out.print("[");
            for (int i = 0; i < arr.length; i++) {
                if(i == arr.length - 1){
                    System.out.println(arr[i] + "]");
                }else{
                    System.out.print(arr[i] + ", ");
                }
            }
        }
    }

7.4 数组最大值

需求:设计一个方法用于获取数组中元素的最大值

思路:

    ①定义一个数组,用静态初始化完成数组元素初始化

    ②定义一个方法,用来获取数组中的最大值,最值的认知和讲解我们在数组中已经讲解过了

    ③调用获取最大值方法,用变量接收返回结果

    ④把结果输出在控制台

代码:

    public class MethodTest02 {
        public static void main(String[] args) {
            //定义一个数组,用静态初始化完成数组元素初始化
            int[] arr = {12, 45, 98, 73, 60};
    
            //调用获取最大值方法,用变量接收返回结果
            int number = getMax(arr);
    
            //把结果输出在控制台
            System.out.println("number:" + number);
        }
    
        //定义一个方法,用来获取数组中的最大值
        /*
            两个明确:
                返回值类型:int
                参数:int[] arr
         */
        public static int getMax(int[] arr) {
            int max = arr[0];
    
            for(int x=1; x<arr.length; x++) {
                if(arr[x] > max) {
                    max = arr[x];
                }
            }
            return max;
        }
    }

7.6 获取索引

需求:

定义一个方法获取数字,在数组中的索引位置,将结果返回给调用处,如果有重复的,只要获取第一个即可。

代码示例:

package com.itheima.demo;

public class Test4 {
    public static void main(String[] args) {
        //定义一个方法获取数字,在数组中的索引位置,将结果返回给调用处
        //如果有重复的,只要获取第一个即可

        int[] arr = {1,2,3,4,5};
        int index = contains(arr, 3);
        System.out.println(index);
    }

    //1. 我要干嘛?判断数组中的某一个数是否存在
    //2. 需要什么?数组 数字
    //3. 调用处是否需要继续使用?返回
    //获取number在arr中的位置
    public static int contains(int[] arr, int number) {
        //遍历arr得到每一个元素
        for (int i = 0; i < arr.length; i++) {
            //拿着每一个元素跟number比较
            if(arr[i] == number){
                //如果相等,表示找到了
                return i;
            }
        }
        //当循环结束之后,如果还不能返回索引,表示数组中不存在该数据
        //可以返回-1
        return -1;
    }
}

————————————————

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

原文链接:https://blog.csdn.net/qq_69748833/article/details/132125754