Java方法详细介绍(二)

简介: Java方法详细介绍(二)

5. 方法的注意事项



5.1 方法的通用格式(掌握)


格式:


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


  • 解释:


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


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


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


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


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


方法体 完成功能的代码块


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


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


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


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


  • 调用方法时的注意:


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


  • 非void类型的方法,推荐用变量接收调用



5.2 方法的注意事项


方法不能嵌套定义


示例代码:


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语句后面不能跟数据或代码
    }
}


6. 方法重载


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. 方法的参数传递



7.1 方法参数传递基本类型(理解)


测试代码:


package com.itheima.param;
public class Test1 {
    /*
         方法参数传递为基本数据类型 :
                传入方法中的, 是具体的数值.
     */
    public static void main(String[] args) {
        int number = 100;
        System.out.println("调用change方法前:" + number);
        change(number);
        System.out.println("调用change方法后:" + number);
    }
    public static void change(int number) {
        number = 200;
    }
}


结论:


基本数据类型的参数,形式参数的改变,不影响实际参数


结论依据:


每个方法在栈内存中,都会有独立的栈空间,方法运行结束后就会弹栈消失


7.2 方法参数传递引用类型


测试代码:


package com.itheima.param;
public class Test2 {
    /*
         方法参数传递为引用数据类型 :
                传入方法中的, 是内存地址.
     */
    public static void main(String[] args) {
        int[] arr = {10, 20, 30};
        System.out.println("调用change方法前:" + arr[1]);
        change(arr);
        System.out.println("调用change方法后:" + arr[1]);
    }
    public static void change(int[] arr) {
        arr[1] = 200;
    }
}


结论:


对于引用类型的参数,形式参数的改变,影响实际参数的值


结论依据:


引用数据类型的传参,传入的是地址值,内存中会造成两个引用指向同一个内存的效果,所以即使方法弹栈,堆内存中的数据也已经是改变后的结果


7.3 数组遍历


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


思路:


因为要求结果在一行上输出,所以这里需要在学习一个新的输出语句


System.out.print(“内容”);
System.out.println(“内容”); 输出内容并换行
System.out.print(“内容”); 输出内容不换行
System.out.println(); 起到换行的作用


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


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


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


调用遍历方法


代码:


package com.itheima.test;
public class Test1 {
    /*
        需求:设计一个方法用于数组遍历,要求遍历的结果是在一行上的。例如:[11, 22, 33, 44, 55]
        思路:
            1.定义一个数组,用静态初始化完成数组元素初始化
            2.定义一个方法,对数组进行遍历
            3.遍历打印的时候,数据不换行
            4.调用遍历方法
     */
    public static void main(String[] args) {
        // 1.定义一个数组,用静态初始化完成数组元素初始化
        int[] arr = {11, 22, 33, 44, 55};
        // 4.调用遍历方法
        printArray(arr);
        System.out.println("另外一段代码逻辑 ");
    }
    /*
        2.定义一个方法,对数组进行遍历
        1, 参数           int[] arr
        2, 返回值类型      void
     */
    public static void printArray(int[] arr){
        System.out.print("[");
        for (int i = 0; i < arr.length; i++) {
            if(i == arr.length -1){
                // 如果满足条件, 说明是最后一个元素, 最后一个元素, 特殊处理
                System.out.println(arr[i] + "]");
            }else{
                // 3.遍历打印的时候,数据不换行
                System.out.print(arr[i] + ", ");
            }
        }
    }
}


7.4 数组最大值


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


思路:


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


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


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


④把结果输出在控制台


代码:


package com.itheima.test;
public class Test2 {
    /*
        需求:设计一个方法用于获取数组中元素的最大值
        思路:
            1.定义一个数组,用静态初始化完成数组元素初始化
            2.定义一个方法,用来获取数组中的最大值
            3.调用获取最大值方法,用变量接收返回结果
            4.把结果输出在控制台
     */
    public static void main(String[] args) {
        // 1.定义一个数组,用静态初始化完成数组元素初始化
        int[] arr = {11, 55, 22, 44, 33};
        // 3.调用获取最大值方法,用变量接收返回结果
        int max = getMax(arr);
        //  4.把结果输出在控制台
        System.out.println(max);
    }
    /*
        2.定义一个方法,用来获取数组中的最大值
        1, 参数       int[] arr
        2, 返回值类型  int
     */
    public static int getMax(int[] arr){
        int max = arr[0];
        for (int i = 1; i < arr.length; i++) {
            if(max < arr[i]){
                max = arr[i];
            }
        }
        return max;
    }
}



7.5 方法同时获取数组最大值和最小值


需求:设计一个方法,该方法能够同时获取数组的最大值,和最小值


注意: return语句, 只能带回一个结果.


代码:


public class Test3 {
    /*
        需求:设计一个方法,该方法能够同时获取数组的最大值,和最小值
        注意: return语句, 只能带回一个结果.
     */
    public static void main(String[] args) {
        int[] arr = {11,55,33,22,44};
        int[] maxAndMin = getMaxAndMin(arr);
        System.out.println(maxAndMin[0]);
        System.out.println(maxAndMin[1]);
    }
    public static int[] getMaxAndMin(int[] arr){
        int max = arr[0];
        for (int i = 1; i < arr.length; i++) {
            if(max < arr[i]){
                max = arr[i];
            }
        }
        int min = arr[0];
        for (int i = 1; i < arr.length; i++) {
            if(min > arr[i]){
                min = arr[i];
            }
        }
        int[] maxAndMin = {min, max};
        return maxAndMin;
    }
}
目录
相关文章
|
15天前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
55 4
|
25天前
|
Java API
Java 对象释放与 finalize 方法
关于 Java 对象释放的疑惑解答,以及 finalize 方法的相关知识。
45 17
|
19天前
|
Java 测试技术 Maven
Java一分钟之-PowerMock:静态方法与私有方法测试
通过本文的详细介绍,您可以使用PowerMock轻松地测试Java代码中的静态方法和私有方法。PowerMock通过扩展Mockito,提供了强大的功能,帮助开发者在复杂的测试场景中保持高效和准确的单元测试。希望本文对您的Java单元测试有所帮助。
44 2
|
1月前
|
算法 Java Linux
java制作海报二:java使用Graphics2D 在图片上合成另一个照片,并将照片切割成头像,头像切割成圆形方法详解
这篇文章介绍了如何使用Java的Graphics2D类在图片上合成另一个照片,并将照片切割成圆形头像的方法。
49 1
java制作海报二:java使用Graphics2D 在图片上合成另一个照片,并将照片切割成头像,头像切割成圆形方法详解
|
27天前
|
Java 开发者
在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口
【10月更文挑战第20天】在Java多线程编程中,创建线程的方法有两种:继承Thread类和实现Runnable接口。本文揭示了这两种方式的微妙差异和潜在陷阱,帮助你更好地理解和选择适合项目需求的线程创建方式。
19 3
|
29天前
|
Java 大数据 API
别死脑筋,赶紧学起来!Java之Steam() API 常用方法使用,让开发简单起来!
分享Java Stream API的常用方法,让开发更简单。涵盖filter、map、sorted等操作,提高代码效率与可读性。关注公众号,了解更多技术内容。
|
27天前
|
Java 开发者
在Java多线程编程中,选择合适的线程创建方法至关重要
【10月更文挑战第20天】在Java多线程编程中,选择合适的线程创建方法至关重要。本文通过案例分析,探讨了继承Thread类和实现Runnable接口两种方法的优缺点及适用场景,帮助开发者做出明智的选择。
17 2
|
27天前
|
安全 Java
Java多线程通信新解:本文通过生产者-消费者模型案例,深入解析wait()、notify()、notifyAll()方法的实用技巧
【10月更文挑战第20天】Java多线程通信新解:本文通过生产者-消费者模型案例,深入解析wait()、notify()、notifyAll()方法的实用技巧,包括避免在循环外调用wait()、优先使用notifyAll()、确保线程安全及处理InterruptedException等,帮助读者更好地掌握这些方法的应用。
17 1
|
27天前
|
Java 开发者
Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点
【10月更文挑战第20天】Java多线程初学者指南:介绍通过继承Thread类与实现Runnable接口两种方式创建线程的方法及其优缺点,重点解析为何实现Runnable接口更具灵活性、资源共享及易于管理的优势。
33 1
|
27天前
|
Java
在Java多线程编程中,`wait()`和`notify()`方法的相遇如同一场奇妙的邂逅
在Java多线程编程中,`wait()`和`notify()`方法的相遇如同一场奇妙的邂逅。它们用于线程间通信,使线程能够协作完成任务。通过这些方法,生产者和消费者线程可以高效地管理共享资源,确保程序的有序运行。正确使用这些方法需要遵循同步规则,避免虚假唤醒等问题。示例代码展示了如何在生产者-消费者模型中使用`wait()`和`notify()`。
25 1
下一篇
无影云桌面