java中方法的使用

方法的使用

  • 方法的概念
    • 什么是方法
    • 方法定义
    • 方法的调用过程
    • 实参和形参的关系
  • 方法重载
    • 为什么需要方法重载
    • 方法重载的概念
    • 方法签名
  • 递归
    • 递归的概念
    • 递归过程分析
    • 递归练习

方法的概念

什么是方法

方法就是一个代码片段,类似于C语言的函数。
方法存在的意义:

  1. 是能够模块化的组织代码(当代码规模比较复杂的时候)
  2. 做到代码被重复使用,一份代码可以在多个位置使用
  3. 让代码更好理解更简单
  4. 直接调用现有方法使用,不用重复写一份代码

方法定义

语法格式:

//方法定义
修饰符 返回值类型 方法名称([参数类型 形参...]){
	方法体代码;
	[return 返回值];
}

例子1:实现一个函数,用于检测年份是否为闰年

public static boolean isLeapYear(int year){
        if ((year % 400 == 0) || ((year % 100 != 0) && (year % 4 == 0))){
            return true;
        }
        return false;
    }
public static void main(String[] args) {
        int year = 2023;
        if (isLeapYear(year)){
            System.out.println("是闰年");
        }else{
            System.out.println("不是闰年");
        }
    }

注意:

  • 返回值类型:如果方法有返回值,返回值类型必须要与返回的实体类型一致,如果没有返回值,必须写成void
  • 方法名字:采用小驼峰命名(首个单词的首个字母小写,后续单词首字母大写)
  • 参数列表:如果方法没有参数。()中什么都不写,如果有参数,需指定参数类型,多个参数之间用逗号隔开
  • 方法体:方法内部要执行的语句
  • 在java当中,方法必须写在类当中
  • 在java中,方法不能嵌套定义
  • 在java中,没有方法声明一说

方法的调用过程

调用方法–>传递参数–>找到方法地址–>执行被调方法的方法体–>被调方法结束返回–>回到主调方法继续往下执行
注意:

  • 定义方法的时候,不会执行方法的代码,只有调用的时候才会执行
  • 一个方法可以被多次调用
    例子:计算 1! + 2! + 3! + 4! + 5!
//计算 1! + 2! + 3! + 4! + 5!
    public static int func(int n){
        int result = 1;
        for (int i = 1; i <= n; i++) {
            result *= i;
        }
        return result;
    }

    public static void main(String[] args) {
        int sum = 0;
        for (int i = 1; i <= 5; i++) {
            sum += func(i);
        }
        System.out.println(sum);
    }

实参和形参的关系

java当中方法的形参相当于数学函数的自变量,用来接收函数调用时传递的值,形参的名字是可以随意取的,对方法没有任何影响,形参只是方法在定义时需要借助的一个变量,用来保存方法在调用时传递过来的值。

public static int add(int a, int b){    //a, b是形参
        return a + b;
    }
public static void main(String[] args){
        int ret = add(2,3); //2,3是实参,a,b分别用来保存2,3,在调用时传给形参a和b
        System.out.println(ret);
    }

注意:在java中,实参的值永远是拷贝到形参中,形参和实参本质是两个实体。
例子:交换两个整型变量

public static void swap(int a, int b){
            int tmp = a;
            a = b;
        b = tmp;
        System.out.println("swap:a =  " + a + " b = " + b);
    }

    public static void main(String[] args) {
        int a =10;
        int b = 20;
        swap(a, b);
        System.out.println("main:a =  " + a + " b = " + b);
        //运行结果:
        //swap:a =  20 b = 10
        //main:a =  10 b = 20
    }

可以看到,在swap交换之后,形参a,b值发生了改变,但是main方法中a和b还是交换之前的值,即没有交换成功。
原因:因为实参a,b是main方法中的变量,其空间在main方法的栈中,而形参a和b是swap方法中的两个变量,a和b的空间在swap方法运行时的栈中,因此实参a和b与形参a和b是两个没有关联性的变量,在swap方法调用时,只是将实参a和b值拷贝一份传递给了形参a和b,因此对形参a和b操作不会对实参a和b产生任何影响
注意:对于基础类型,形参相当于实参的拷贝,即传值调用
解决方法:传引用类型参数(例如通过数组来解决)(java中,拿不到栈上变量的地址)

public static void swap(int[] arr){
        int tmp = arr[0];
        arr[0] = arr[1];
        arr[1] = tmp;
    }

    public static void main(String[] args) {
        int[] arr = {10,20};
        swap(arr);
        System.out.println("main:"+arr[0] + " " + arr[1]);

    }

方法重载

为什么需要方法重载

public static int add(int a, int b){
        return a + b;
    }

    public static void main(String[] args) {
        int x = 10;
        int y = 20;
        int ret1 = add(x,y);
        double a = 2.0;
        double b = 1.0;
        double ret2 = add(a,b);//编译报错:不兼容的类型: 从double转换到int可能会有损失
    }

任何解决呢
我们可能会采取再写另外一个方法

public static int add(int a, int b){
        return a + b;
    }

    public static double addDouble(double a, double b){
        return a + b;
    }

    public static void main(String[] args) {
        int x = 10;
        int y = 20;
        int ret1 = add(x,y);
        double a = 2.0;
        double b = 1.0;
        double ret2 = addDouble(a,b);//编译报错:不兼容的类型: 从double转换到int可能会有损失
    }

但是随着需求和要求增加,每增加新类型参数就需要新写一个方法,重新起一个方法名,想许多不同的方法名是一件比较烦人的事,能否都是同一个方法名呢?

方法重载的概念

在java中,方法是可以重载的,在java中,如果多个方法的名字相同,参数列表不同,则说该几种方法被重载了。
例子:

public static int add(int a, int b){
        return a + b;
    }

    public static double add(double a, double b){
        return a + b;
    }

    public static double add(double a, double b, double c){
        return a + b + c;
    }

    public static void main(String[] args) {
        int x = 10;
        int y = 20;
        int ret1 = add(x,y);//调用add(int,int)
        double a = 2.0;
        double b = 1.0;
        double c = 3.0;
        double ret2 = add(a,b);//调用add(double,double)
        double ret3 = add(a,b,c);//调用add(double,double,double)
    }

注意:

  1. 方法名必须相同
  2. 参数列表必须不同(参数的个数、参数的类型、类型的次序)
  3. 与返回值类型是否相同无关
  4. 如果两个数仅仅只是因为返回值类型不同,是不能构成重载的,会编译出错
  5. 编译器在编译代码时,会对实参类型进行推演,根据推演的结果来确定调用哪个方法

方法签名

方法签名:经过编译器编译修改过之后方法的最终名字。具体方式:方法全路径名+参数列表+返回值类型,构成方法完整的名字。

public static int add(int a, int b){
        return a + b;
    }

    public static double add(double a, double b){
        return a + b;
    }

    public static double add(double a, double b, double c){
        return a + b + c;
    }

    public static void main(String[] args) {
        int x = 10;
        int y = 20;
        int ret1 = add(x,y);//调用add(int,int)
        double a = 2.0;
        double b = 1.0;
        double c = 3.0;
        double ret2 = add(a,b);//调用add(double,double)
        double ret3 = add(a,b,c);//调用add(double,double,double)
    }

上述代码经过编译之后,然后使用JDK自带的javap反汇编工具查看,具体操作:

  1. 先对工程进行编译生成.class字节码文件
  2. 在控制台中进入到要查看的.class所在的目录
  3. 输入:javap -v 字节码文件名字即可
    在这里插入图片描述
特殊字符数据类型
Vvoid
Zboolean
Bbyte
Cchar
Sshort
Iint
Jlong
Ffloat
Ddouble
[数组(以[开头,配合其他的特殊字符,表述对应数据类型的数组,几个[表述几维数组)
L引用类型,以L开头,以;结尾,中间是引用类型的全类名

递归

递归的概念

一个方法在执行过程中调用自身,即”递归“
解决递归问题:

  1. 有一个递归公式
  2. 找到当前递归问题的解决条件
    例子:用递归求N的阶乘
public static int func(int n){
        if (n == 1){
            return 1;
        }
        return n * func(n - 1);
    }

    public static void main(String[] args) {
        int n = 5;
        int ret = func(5);
        System.out.println(ret);
        //结果是120
    }

递归过程分析

理解清楚递归,首先必须理解清楚“方法的执行过程”,尤其是“方法执行结束之后,回到调用位置继续往下执行”
在这里插入图片描述

关于调用栈
方法调用的时候,会有一个“栈”这样的内存空间描述当前的调用关系,称为调用栈。
每一次的方法调用就称为一个“栈帧”,每个栈帧中包含了这次调用的参数是哪些,返回到哪里继续执行等信息。

递归练习

例子1:按顺序打印数字的每一位(例如1234,打印1 2 3 4)

//按顺序打印数字的每一位(例如1234,打印1 2 3 4)
    public static void print(int n){
        if (n > 9){
            print(n / 10);
        }
        System.out.print(n % 10 + " ");
    }
    public static void main(String[] args) {
        int num = 1234;
        print(num);
    }

例子2:递归求1 + 2 + 3 + … + 9 + 10

//递归求1 + 2 + 3 + ... + 9 + 10
    public static int sum(int n){
        if (n == 1){
            return 1;
        }
        return n + sum(n -1);
    }

    public static void main(String[] args) {
        int num = 10;
        int ret = sum(num);
        System.out.println(ret);
        //计算结果是55
    }

例子3:写一个递归方法,输入一个非负整数,返回组成它的数字之和. 例如,输入 1729, 则应该返回1+7+2+9,它的和是19

//写一个递归方法,输入一个非负整数,返回组成它的数字之和. 例如,输入 1729, 则应该返回1+7+2+9,它的和是19
    public static int sum(int n){
        if (n < 10) {
            return n;
        }
        return n % 10 + sum(n / 10);
    }

    public static void main(String[] args) {
        int num = 1729;
        int ret = sum(num);
        System.out.println(ret);
    }

例子4:求斐波那契数列的第N项

//求斐波那契数列的第N项
    public  static int fib(int n){
        if (n == 1 || n == 2){
            return 1;
        }
        return fib(n - 2) + fib(n-1);
    }

    public static void main(String[] args) {
        System.out.println(fib(5));
    }

当我们求fib(40)的时候发现程序运行速度很慢,原因是进行了大量的重复运算

public  static int fib(int n){
        if (n == 1 || n == 2){
            return 1;
        }
        if (n == 3){
            count++;
        }
        return fib(n - 2) + fib(n-1);
    }

    public static void main(String[] args) {
        System.out.println(fib(40));
        System.out.println(count );
    }
    //计算结果:102334155
	//			39088169(fib(3)计算的次数)

我们可以使用循环求斐波那契数列,避免冗余的计算。

public static int fib(int n){
        int num1 = 1;
        int num2 = 1;
        for (int i = 2; i < n; i++) {
            int tmp = num1 + num2;
            num1 = num2;
            num2 = tmp;
        }
        return num2;
    }

    public static void main(String[] args) {
        System.out.println(fib(40));
    }

———————————————————————————————————————————
对于方法的学习我们先了解到这里,后续我们继续学习和了解java的内容。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/788710.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

LabVIEW自动测控与故障识别系统

使用LabVIEW 2019在Win10 64位系统上开发自动测控软件&#xff0c;通过与基恩士NR-X100数据采集仪通讯&#xff0c;实时采集和分析数据&#xff0c;自动识别判断产品是否合格&#xff0c;并增加数据记录和仿真功能。 具体解决方案&#xff1a; 1. 系统架构设计 硬件接口&#…

《AIGC:智能创作时代》:AI创作革命来临,你准备好了吗?

想象一下&#xff0c;你正在欣赏一幅精美的画作&#xff0c;惊叹于其细腻的笔触和独特的构图。然而&#xff0c;当你得知这幅作品是由人工智能创作时&#xff0c;你会作何感想&#xff1f;这不再是科幻小说中的场景&#xff0c;而是我们正在经历的现实。 在这个AI技术飞速发展的…

LT7911UX 国产原装 一拖三 edp 转LVDS 可旋转 可缩放

2.一般说明 该LT7911UX是一种高性能Type-C/DP1.4a到MIPI或LVDS芯片的VR/显示应用。HDCP RX作为HDCP转发器的上游&#xff0c;可以与其他芯片的HDCP TX配合实现转发器功能。 对于DP1.4a输入&#xff0c;LT7911UX可配置为1/2/4通道。自适应均衡使其适用于长电缆应用&#xff0c;最…

2,区块链、数字货币及其应用场景(react+区块链实战)

2&#xff0c;区块链、数字货币及其应用场景&#xff08;react区块链实战&#xff09; 一、什么是区块链&#xff1f;1 ibloackchain&#xff08;1&#xff09;安装ibloackchain&#xff08;2&#xff09;Blance查询余额&#xff08;3&#xff09;Mine挖矿&#xff08;4&#x…

无损音频格式 FLAC 转 MP3 音频图文教程

音频文件的格式多样&#xff0c;每种格式都有其独特的特点与适用场景。FLAC&#xff08;Free Lossless Audio Codec&#xff09;&#xff0c;作为一种无损音频压缩格式&#xff0c;因其能够完美保留原始音频数据的每一个细节而备受音频发烧友和专业人士的青睐。 然而&#xff0…

在表格中选中el-radio后, 怎么获取选中的这一行的所有数据?

演示: 图中, 选中这行数据后, 怎么获取到当前的数据? 代码: <tr v-for"item in gridData"><td><input type"radio" v-model"checkout" change"getDateFn" :data-type"item.articleType" :data-channelNam…

Spring Cloud Alibaba -- 分布式定时任务解决方案(轻量级、快速构建)(ShedLock 、@SchedulerLock )

文章目录 一、 ShedLock简介二、 SchedulerLock三、基于Mysql方式使用步骤1.建表2.引入依赖3.Mysql连接配置4.ScheduledLock配置5.启动类配置6.创建定时任务7.启动多个项目服务进行测试8.SchedulerLock注解说明 四、使用注意事项 一、 ShedLock简介 ShedLock 是一个用于 Java …

中职网络安全B模块渗透测试server2003

通过本地PC中渗透测试平台Kali对服务器场景Windows进⾏系统服务及版本扫描渗透测 试&#xff0c;并将该操作显示结果中Telnet服务对应的端⼝号作为FLAG提交 使用nmap扫描发现目标靶机开放端口232疑似telnet直接进行连接测试成功 Flag&#xff1a;232 通过本地PC中渗透测试平台…

VMware取消中文支持,替换vSAN解决方案提上日程!

What is vSAN &#xff1f; 是一款软件定义的企业存储解决方案&#xff0c;支持超融合基础架构系统。vSAN与VMware vSphere 完全集成在一起&#xff0c;作为ESXi Hypervisor内的分布式软件层&#xff0c;通过整合、池化ESXi各个主机上的存储资源&#xff0c;为vSphere虚拟化平…

Apache中使用SSI设置

先停服务在修改httpd.conf&#xff0c;备份下 Apache\Apache24\conf 设置httpd.conf LoadModule ssl_module modules/mod_ssl.so 取消该命令前的注释符# AddType text/html .shtml AddOutputFilter INCLUDES .shtml 取消该命令前的注释符# 加入html AddType text/html .…

mov视频怎么改成mp4?把mov改成MP4的四个方法

mov视频怎么改成mp4&#xff1f;选择合适的视频格式对于确保内容质量和流通性至关重要。尽管苹果公司的mov格式因其出色的视频表现备受赞誉&#xff0c;但在某些情况下&#xff0c;它并非最佳选择&#xff0c;因为使用mov格式可能面临一些挑战。MP4格式在各种设备&#xff08;如…

中职网络安全wire0077数据包分析

从靶机服务器的FTP上下载wire0077.pcap&#xff0c;分析该文件&#xff0c;找出黑客入侵使用的协议&#xff0c;提交协议名称 SMTP 分析该文件&#xff0c;找出黑客入侵获取的zip压缩包&#xff0c;提交压缩包文件名 DESKTOP-M1JC4XX_2020_09_24_22_43_12.zip 分析该文件&…

Mysql练习题目【7月10日更新】

七、Mysql练习题目 https://zhuanlan.zhihu.com/p/38354000 1. 创建表 创建学生表 mysql> create table if not exists student(-> student_id varchar(255) not null,-> student_name varchar(255) not null,-> birthday date not null,-> gender varchar(…

算法金 | 12 个最佳 Python 代码片段,帮我完成工作自动化,香~

​大侠幸会幸会&#xff0c;我是日更万日 算法金&#xff1b;0 基础跨行转算法&#xff0c;国内外多个算法比赛 Top&#xff1b;放弃 BAT Offer&#xff0c;成功上岸 AI 研究院 Leader&#xff1b; Python是一种多功能的编程语言&#xff0c;它提供了各种功能和库来有效地自动化…

【分布式系统管理框架】Zookeeper集群

1、Zookeeper &#xff08;1&#xff09;Zookeeper定义 Zookeeper是一个开源的&#xff0c;为分布式框架提供协调服务的Apache项目。 &#xff08;2&#xff09;Zookeeper工作机制 Zookeeper从设计模式角度来理解&#xff1a;是一个基于观察者模式设计的分布式服务管理框架…

使用linux的mail命令发送html格式的邮件

1、关闭本机的sendmail服务或者postfix服务 #执行下面的命令&#xff0c;各位大侠都对号入座吧 #sendmial service sendmail stop chkconfig sendmail off #postfix service postfix stop chkconfig postfix off#再狠一点就直接卸载吧.. yum remove sendmail yum remove postf…

大小端详解

引例 我们知道整形(int)是4个字节&#xff0c;例如随便举个例子&#xff1a;0x01020304&#xff0c;它一共占了四个地址位&#xff0c;01,02,03,04分别占了一个字节&#xff08;一个字节就对应了一个地址&#xff09;。 那么就会有个问题&#xff1a;我们的01到底是存储在高地…

20_Inception V3深度学习图像分类算法

回顾GoogleNet:传送门 1.1 介绍 InceptionV3是Google开发的一种深度卷积神经网络架构&#xff0c;它是Inception系列网络中的第三代模型&#xff0c;由Christian Szegedy等人在论文《Rethinking the Inception Architecture for Computer Vision》中提出&#xff0c;该论文发…

在vue3中,手写父子关联,勾选子级父级关联,取消只取消当前子级,父节点不动

树形控件选择子级勾选父级&#xff0c;以及所有子级&#xff0c; 取消勾选仅取消子级 在项目中&#xff0c;可能会遇到这种场景&#xff0c;比如权限配置的时候&#xff0c;页面权限和菜单权限以tree的形式来配置&#xff0c;而且不用半选&#xff0c;菜单在页面的下面&#xf…

基于SpringBoot构造超简易QQ邮件服务发送 第二版

目录 追加 邮箱附件 添加依赖 编码 测试 第二版的更新点是追加了 邮箱附件功能 ( 后期追加定时任务 ) 基于SpringBoot构造超简易QQ邮件服务发送(分离-图解-新手) 第一版 追加 邮箱附件 添加依赖 <!-- 电子邮件 --><dependency><groupId>org.spri…