Java后端——方法

1方法概述

1.1方法的概念

方法(method)是将具有独立功能的代码块组织成为一个整体,使其具有特殊功能的代码集

注意:

        方法必须先创建才能使用,该过程是方法的定义

        方法创建按后并不能直接运行,需要手动使用后才能执行,该过程是方法的调用

2方法的定义和调用

2.1 无参数方法定义和调用

        定义格式

public static void 方法名(){
    方法体;
}
例:
public static void example (){
    System.out.println("welcome");
}

        调用格式

方法名();
例:
example ();

注意
         方法必须先定义,后调用,否则会报错

2.2方法的调用过程

总结:每个方法在被调用的时候, 都会进入栈内存,并且拥有自己独立的空间,方法内部代码调用完毕之后,会从栈内存弹出消失。

2.3方法练习——奇偶判断

需求:判断一个数是奇数还是偶数

代码:

public class Main {
    public static void main(String[] args) {
        int a=10;
        pan_duan(a);
    }
    public static void pan_duan (int num){
        if (num %2 == 0){
            System.out.println("偶数");
        }
        else {
            System.out.println("奇数");
        }
    }
}

3带参数方法的定义和调用 

3.1带参数方法的定义和调用

        定义格式

public static void 方法名 (参数1) {
	方法体;
}

public static void 方法名 (参数1, 参数2, 参数3...) {
	方法体;
}

例子:
public static void isEvenNumber(int number){
    ...
}
public static void getMax(int num1, int num2){
    ...
}

 注意方法定义时,参数中的数据类型与变量名都不能缺少,缺少任意一个程序都将报错

方法定义多个时,多个参数之间需要用逗号(,)隔开

        调用格式:

方法名 (参数);

方法名(参数1,参数2);

例:

isEvenNumber(10);
​getMax(10,20);

         方法调用的时候,参数的数量与类型必须要与方法定义的类型匹配,不然就会报错

3.2形参和实参

1、形参:

方法定义中的参数

等同于变量定义格式:例如 int number

2、实参:

方法调用中的参数

等同于使用变量或者常量:例如 10 number

3.3带参数方法的练习——打印n-m之间所有的奇数

需求:设计一个方法(print) 用于打印 n 到 m 之间所有的奇数

思路:

1、定义方print()

2、为方法添加两个int类型的形参,准备接受调用者传递过来的实参

3、方法中设计for循环,从n开始,到m结束

4、循环中加入if判断,如果奇数,则打印

5、main方法中调用print()方法

代码:

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("输入n: ");
        int n = sc.nextInt();
        System.out.println("输入n: ");
        int m = sc.nextInt();
        print(n,m);
    }
    public static void print(int n,int m){
        for(int i=n;i<=m;i++){
            if (i % 2 != 0 ){
                System.out.print(i+",");
            }
        }
    }
}

4.带返回值方法的调用

4.1带返回值方法的定义和调用

        定义格式

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

例:

public static boolean isEvenNumber( int number ) {           
	return true ;
}
public static int getMax( int a, int b ) {
	return  100 ;
}

注意:方法定义时 return 后面的返回值与方法定义上的数据类型要一致,不然会报错

        调用格式

方法名 ( 参数 ) ;
数据类型 变量名 = 方法名 ( 参数 ) ;

例:

isEvenNumber ( 5 ) ;
boolean  flag =  isEvenNumber ( 5 ); 

注意: 方法的返回值通常会使用变量来接受,否则返回值将无意义

4.2带返回值方法的练习——求两个数的最大值

需求:设计一个方法可以获取两个数的较大值,数据来自于参数

思路:

1、定义一个返回值方法,申明两个参数接受计算的值,求出结果并返回

2、使用 if 语句来判断 a ,b 的最大值,然后根据 return 具体结果

3、在 main ()方法中调用

代码:

public class Main {
    public static void main(String[] args) {
        int a = 10;
        int b = 20;
        int max = gexMax(a,b);
        System.out.println(max);
    }
    public static int gexMax(int a,int b){
        return a>b?a:b;
    }
}

5方法的注意事项 

方法中不能嵌套定义

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)

思路:

1、定义比较两个整数是否相同的 compare()方法,参数选择两个 int 类型

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

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

4、完成方法的调用

代码:

public class Main {
    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));
    }
    public static byte compare (byte a, byte b) {
        if (a == b) {
         return 0;
        }
        else  {
            return -1;
        }
    }
    public static byte compare (short a, short b) {
        if (a == b) {
            return 0;
        }
        else  {
            return -1;
        }
    }
    public static byte compare (int a, int b) {
        if (a == b) {
            return 0;
        }
        else  {
            return -1;
        }
    }
    public static byte compare (long a, long b) {
        if (a == b) {
            return 0;
        }
        else  {
            return -1;
        }
    }
}

7方法的参数传递

7.1 方法参数传递——基本类型

测试代码:

package com.wedu.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.wedu.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;
    }
}

结果:

 

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

结论依据:

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

  • 8
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值