自学内容网 自学内容网

Java篇方法的使用

目录

前言

一. 方法概念及使用

1.1 什么是方法

1.2 方法的定义

 1.3 形参与实参的关系

二. 方法重载

 2.1 方法签名

 三. 递归

3.1 递归的概念

3.2 递归的思想

3.3 递归的限制条件

3.4 递归举例练习

结语


前言

相信大家在学校都是校草级别的人物,每天总是有很多小姐姐来要你们的微信,导致每次都要重复被要微信的过程,那么有什么方法能够解决这个重复的过程呢?于是你将你的微信号和帅帅的照片挂到了学校的校园墙中,让小姐姐自行添加你的微信,从而解决了被要微信这个重复的过程,那么在我们的Java编程中也是需要定义方法来解决重复的问题,接下来我们来学习一下方法的使用吧~

一. 方法概念及使用

在编程中,假设有某段功能的代码可能频繁使用到,并且在每个位置都重新实现一遍,这会使代码变得繁琐、开发效率低下、程序不利于维护等缺点,所以我们将频繁使用的代码封装成方法,需要使用时调用该方法即可。

1.1 什么是方法

方法就是一个代码片段 . 类似于  C 语言中的 " 函数 " 。方法存在的意义:
1. 是能够模块化的组织代码 ( 当代码规模比较复杂的时候 )
2. 做到代码被重复使用 , 一份代码可以在多个位置使用
3. 让代码更好理解,看起来更加简洁
4. 直接调用现有方法开发 , 不必重新写重复的代码

 例如我们要写一个方法来判断素数:

 public static void func(int a) {
        boolean flag = true;
        for(int i=2; i<=a-1; i++){
            if(a%i == 0){
                System.out.println(a+"不是素数");
               return;
            }
        }
        System.out.println(a+"是素数");
    }

当我们在main方法中需要判断一个数是否是素数时,则直接调用func( )方法即可,无需再重新编写代码。

1.2 方法的定义

方法定义的语法:

修饰符 返回值类型 方法名称([ 参数类型 形参 ]){
        方法体代码;
        return 返回值;
    }
    例如上述的func( )方法:
    public static   void    func(int a)
        修饰符     返回类型     方法名称(参数类型 形参)

方法定义的几个注意事项:

1. 返回值类型:如果方法有返回值,返回值类型必须要与返回的实体类型一致,如果没有返回值,必须写成 void
2. 方法名字:采用小驼峰命名
3. java 当中,方法必须写在类当中
4. 方法不能嵌套定义
5.  参数列表:如果方法没有参数, () 中什么都不写,如果有参数,需指定参数类型,多个参数之间使用逗号隔开

 1.3 形参与实参的关系

形参是实参的一份临时拷贝,形参拥有独立的内存空间,对形参的改变不会影响实参,什么意思呢?我们来看一段代码:
可以看到我们明明在swap( )方法中交换了a和b的值,但是运行结果却还是没有变化,我们画图演示一下形参与实参在内存中的存储:

从图中可以看到,在调用swap( )方法的时候,会重新开辟一块内存空间来接收实参的值,此时的形参是独立的空间与实参没有任何关系,所以对形参的更改不会影响实参~

二. 方法重载

什么是方法重载呢?我们看个例子:

从上面的代码中我们就可以看到,当我们想要完成不同类型的变量进行相加时,我们就需要写出两个不同的方法,那么要是有多个不同类型的变量呢?此时提供方法的时候,我们时常因为给方法取名而头疼,那么这个时候就可以使用方法重载来解决这个问题

 方法重载的注意事项:

1. 方法名必须相同
2. 参数列表必须不同 ( 参数的个数不同、参数的类型不同、类型的次序必须不同 )
3. 返回值没有要求

 2.1 方法签名

 大家有没有想过在同一个作用域中不能定义两个相同名称的标识符。比如:在方法中不能定义两个名字一样的变量,但是为什么类中就可以定义方法名相同的方法呢?

方法签名:方法签名定义了调用方法之前需要知道的一切信息,经过编译器编译修改过之后方法最终的名字

具体方式:方法全路径名+参数列表+返回值类型,构成方法完整的名字。

 三. 递归

3.1 递归的概念

说到递归相信初学编程的小伙伴真是越发的头疼,递归其实就是方法自己调用自己,“ 递 ”其实就是递推,“ 归 ”即是回归,递归是一种大事化小的解决问题的方法。

3.2 递归的思想

将一个大型复杂的问题层层转化成一个与原问题相似,但是规模更小的子问题来求解,直到子问题不能被拆分,那么递归就结束了,接下来我们一起来看一段代码:

在上面的代码中我们通过main方法调用print( )方法,之后print( )方法一直自己调用自己,程序陷入了死循环,并且造成了栈溢出的异常,所以在使用递归的时候,需要加一个限制条件。

3.3 递归的限制条件

当我们在书写递归程序的时候,必须要有两个必要条件:

1. 递归必须存在限制条件,当满足这个条件时,程序便不在进行递推而是开始回归

2.每次递归调用之后越来越接近这个限制条件

 那么拥有以上两个条件之后,就可以避免程序出现死循环的现象了~

3.4 递归举例练习

经典练习:求n的阶乘

n的阶乘就是1~n的数字进行累积相乘

 那么我们来分析一下这个题目该怎么完成:

//5的阶乘
5!=5 * 4 * 3 * 2 * 1
//4的阶乘
4!=4 * 3 * 2 * 1
以此类推...
 
那么我们是不是可以将5的阶乘看成:
5的阶乘=5 * 4的阶乘
5!=5 * 4!(4的阶乘)
 
而4的阶乘看成
4的阶乘=4 * 3的阶乘
4!=4 * 3!(3的阶乘)
以此类推...

通过上面的分析我们就可以得出阶乘公式:n!=n*(n-1)!,当n等于0时,n!就等于1,此时将这两个运算公式转换成数学中的分段函数,即:

 这个分段函数其实就是N的阶乘的递归公式啦,那么接下来以代码的方式呈现:

public class Test10 {
    public static int Fact(int n) {
        if(n == 0){
            return 1;
        }
        return n*Fact(n-1);
    }

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        System.out.println(Fact(n));
    }
}

递归执行过程图:

 那么通过递归的方式,这道经典的例题就完成了。

注意:递归是一种很好的解决问题的方法,但是和很多技巧一样容易被误用,我们应当合理选择正确的方式解决问题,当冗余计算过多时,往往选择迭代的方式解决问题更为合适,也不容易出现栈溢出的现象。

结语

以上就是本期的全部内容啦,希望大家看完后能够合理运用方法,并且使用合适的方式解决问题,在此感谢大家的观看!!!


原文地址:https://blog.csdn.net/2402_86304740/article/details/143647575

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!