当前位置: 首页 > news >正文

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));}
}

递归执行过程图:

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

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

结语

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


http://www.mrgr.cn/news/75371.html

相关文章:

  • 机器学习(贝叶斯算法,决策树)
  • 【MYSQL】主从复制机制(图解)
  • <tauri><websocket>tauri集成web端使用websocket实现数据通讯
  • Python 占位语句 pass
  • 各种环境换源教程
  • 开源 2 + 1 链动模式、AI 智能名片、S2B2C 商城小程序在用户留存与品牌发展中的应用研究
  • 工控HMI应用场景(1):医疗终端机的界面
  • 全志科技嵌入式面试题及参考答案
  • 手动搭建 Node.js 环境
  • 【论文阅读】Prompt-to-Prompt Image Editing with Cross Attention Control
  • <项目代码>YOLOv8 瞳孔识别<目标检测>
  • Python中的“==”和“is”究竟有何不同?一篇文章让你彻底搞懂!
  • Java 网络编程:Socket 与网络通信
  • 2.6 以太网扩展技术
  • 《向量数据库指南》——Mlivus Cloud:数据安全与合规性的守护者
  • 【月之暗面kimi-注册/登录安全分析报告】
  • Visual Studio 如何在终端窗口内嵌git bash
  • 光伏智能踏勘:让踏勘告别爬屋顶,开启光伏一点通新篇章
  • 社科基金资料汇总(选题、申请、撰写全流程的资料、经典范例和历年数据)1991-2022年
  • 充气膜场馆的保温效果如何?—轻空间
  • Python io.StringIO:高效的可变字符串处理工具
  • 深度学习-卷积神经网络CNN
  • 质数的来源-2
  • 会话信息处理: HttpSession、token序列化、收集登录设备信息、基于`spring-session-data-redis`实现session共享。
  • 数字信号处理Python示例(14)生成锯齿波和三角波
  • TypeORM在Node.js中的高级应用