Java篇方法的使用
目录
前言
相信大家在学校都是校草级别的人物,每天总是有很多小姐姐来要你们的微信,导致每次都要重复被要微信的过程,那么有什么方法能够解决这个重复的过程呢?于是你将你的微信号和帅帅的照片挂到了学校的校园墙中,让小姐姐自行添加你的微信,从而解决了被要微信这个重复的过程,那么在我们的Java编程中也是需要定义方法来解决重复的问题,接下来我们来学习一下方法的使用吧~
一. 方法概念及使用
在编程中,假设有某段功能的代码可能频繁使用到,并且在每个位置都重新实现一遍,这会使代码变得繁琐、开发效率低下、程序不利于维护等缺点,所以我们将频繁使用的代码封装成方法,需要使用时调用该方法即可。
1.1 什么是方法
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. 返回值类型:如果方法有返回值,返回值类型必须要与返回的实体类型一致,如果没有返回值,必须写成 void2. 方法名字:采用小驼峰命名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)!