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

方法

方法

      • 方法(函数)
        • 一、课前问答
        • 二、方法和函数
        • 三、方法的参数
          • 3.1 单个参数
          • 3.2 多个参数
        • 四、方法的返回值
        • 五、方法的多级调用
        • 六、递归

方法(函数)

一、课前问答

1、break和continue的区别

2、嵌套循环的执行流程

3、二进制有哪些运算?简单说明

二、方法和函数

都是指实现特定功能的代码,可以反复使用。

早期称为函数,例如C语言等。

后来出现了Java等面向对象的语言,将程序中的内容称为对象,而对象具备属性和方法。方法具体实现过程与函数一样。只是名称不同。

以下演示一段不规范的代码:

public class Demo01 {public static void main(String[] args) {System.out.println("床前明月光,");System.out.println("----------");System.out.println("疑是地上霜。");System.out.println("----------");System.out.println("举头望明月,");for (int i = 0; i < 10; i++) {System.out.print("-");}System.out.println();System.out.println("低头思故乡。");for (int i = 0; i < 10; i++) {System.out.print("-");}System.out.println();}
}

上面的代码存在冗余,可以定义方法来解决。

定义方法的语法:

public static void 方法名(){

// 方法的主体(功能代码)

}

public class Demo01 {public static void main(String[] args) {System.out.println("床前明月光,");printSign();System.out.println("疑是地上霜。");printSign();System.out.println("举头望明月,");printSign();System.out.println("低头思故乡。");printSign();}public static void printSign() {for (int i = 0; i < 10; i++) {System.out.print("-");}System.out.println();}
}

三、方法的参数

调用方法时,传入的数据叫做参数。

语法:

public static void 方法名称(形参){

}

调用:

方法名称(实参);

形参与实参:形参是形式上的参数,在方法定义时写在方法括号中的变量,在没有被调用时没有实际的值。实参是指方法在调用时传入的实际的值。

3.1 单个参数
public class Demo01 {public static void main(String[] args) {System.out.println("床前明月光,");int n = 6;printSign(n); // 实参System.out.println("疑是地上霜。");printSign(7);System.out.println("举头望明月,");printSign(8);System.out.println("低头思故乡。");printSign(9);}public static void printSign(int count) { // 形参for (int i = 0; i < count; i++) {System.out.print("-");}System.out.println();}
}
3.2 多个参数
public class Demo01 {public static void main(String[] args) {System.out.println("床前明月光,");int n = 6;printSign(n, "#"); // 实参System.out.println("疑是地上霜。");printSign(7, "-");System.out.println("举头望明月,");printSign(8, "~");System.out.println("低头思故乡。");printSign(9, "_");}public static void printSign(int count, String sign) { // 形参for (int i = 0; i < count; i++) {System.out.print(sign);}System.out.println();}
}

注意:多个参数在使用时应该按照参数的类型对应的顺序传入。

四、方法的返回值

语法:

public static 返回值类型 方法名(参数列表){

// 内容

}

调用:

变量 = 方法名(实参);

注意:在方法定义了返回值类型时,必须要返回相应的值,不能有条件返回,也不能多次返回。当执行了返回后,方法调用结束。

public class Demo05 {public static void main(String[] args) {// 调用int s = he(3, 5);System.out.println(s);}private static int he(int m, int n) {int sum = m + n;return sum;}
}

return的两种用法:

一是返回相应类型的值。

二是当方法没有返回值时,直接结束方法,使用return;

public class Demo06 {public static void main(String[] args) {// 调用m1();}private static void m1() {for (int i = 1; i < 20; i++) {for (int j = 1; j < 33; j++) {int k = 100 - i - j;if(i * 5 + j * 3 + k / 3 == 100 && k % 3 == 0) {System.out.println("公鸡"+i+",母鸡"+j+",小鸡" + k);return;}}}}
}

求阶乘之和。

public class Demo07 {// 求1!+2!+3!+4!+...+10!// 10! = 1x2x3x4x5x6x7x8x9x10/*** 求和*/public static void main(String[] args) {int sum = 0;for (int i = 1; i <= 10; i++) {sum += m1(i);}System.out.println("和为" + sum);}/*** 求阶乘* @param i 传入数字* @return*/private static int m1(int i) {int s = 1;for (int j = 1; j <= i; j++) {s *= j;}return s;}
}

求100以内所有质数之和。

public class Demo08 {/*** 求100以内所有的质数之和*/public static void main(String[] args) {int sum = 0;for (int i = 2; i <= 100; i++) {if(m1(i)) {System.out.println(i);sum += i;}}System.out.println("和为" + sum);}/*** 判断一个数字是否质数* @param i 传入数字* @return*/private static boolean m1(int i) {for (int j = 2; j < i; j++) {if(i % j == 0) {return false;}}return true;}
}

注意:Java中只能有一个返回值,切该返回值应该符合返回值类型(包括自动类型转换)。

求1000以内所有的完数之和

public class Demo09 {/*** 求1000以内所有的完数之和*/public static void main(String[] args) {int sum = 0;for (int i = 1; i <= 1000; i++) {if(m1(i)) {System.out.println(i);sum += i;}}System.out.println("和为" + sum);}/*** 判断一个数字是否完数* @param i 传入数字* @return*/private static boolean m1(int i) {int sum = 0;for (int j = 1; j < i; j++) {if(i % j == 0) {sum += j;}}if(sum == i) {return true;}else {return false;}}
}

五、方法的多级调用

一个方法中调用另一个方法,称为多级调用。

public class Demo10 {public static void main(String[] args) {m1();}public static void m1() {System.out.println("m1===start");m2();System.out.println("m1===end");}public static void m2() {System.out.println("m2===start");System.out.println("m2===end");}
}

如果将上面的m2()调用部分换成m1()。则会出现无穷递归,最终结果会报错:Exception in thread “main” java.lang.StackOverflowError

六、递归

递归就是在方法中自己调用自己,需要使用递归。

递归使用时需要注意,一定要有一个出口,在调用链调用时能够正确停止,避免无穷递归。

使用递归实现斐波拉契数列数列:

// 先使用循环
public class Demo11 {public static void main(String[] args) {for (int i = 1; i <= 50; i++) {System.out.println(m1(i));}}/*** 斐波拉契数列* 1 1 2 3 5 8 13...* 前两项为1,后面每一项为前两项之和*/public static long m1(int n) {if(n == 1 || n == 2) {return 1;}else {long a = 1;long b = 1;long c = 0;for (int i = 3; i <= n; i++) {c = a + b;a = b;b = c;}return c;}}
}
public class Demo12 {public static void main(String[] args) {
//		for (int i = 1; i <= 50; i++) {
//			System.out.println(i + "====" + f(i));
//		}f(5);}/*** 斐波拉契数列* 1 1 2 3 5 8 13...* 前两项为1,后面每一项为前两项之和* */public static long f(int n) {if(n == 1 || n == 2) {return 1;}else {return f(n-1) + f(n-2);}}
}

注意:在上面的代码中,使用循环比递归效率要高,因为递归中创建了很多个方法栈。

求n的阶乘:

public class Demo13 {public static void main(String[] args) {System.out.println(f(5));}/*** 求n的阶乘*/public static long f(int n) {if(n == 1) {return 1;}else {return n * f(n-1);}}
}

相关文章:

方法

方法方法&#xff08;函数&#xff09;一、课前问答二、方法和函数三、方法的参数3.1 单个参数3.2 多个参数四、方法的返回值五、方法的多级调用六、递归方法&#xff08;函数&#xff09; 一、课前问答 1、break和continue的区别 2、嵌套循环的执行流程 3、二进制有哪些运算&…...

C/C++实现发送邮件功能(附源码)

C++常用功能源码系列 本文是C/C++常用功能代码封装专栏的导航贴。部分来源于实战项目中的部分功能提炼,希望能够达到你在自己的项目中拿来就用的效果,这样更好的服务于工作实践。 专栏介绍:专栏讲本人近10年后端开发常用的案例,以高质量的代码提取出来,并对其进行了介绍。…...

Java虚拟机JVM-运行时数据区域说明

及时编译器 HotSpot虚拟机中含有两个即时编译器&#xff0c;分别是编译耗时短但输出代码优化程度较低的客户端编译器&#xff08;简称为C1&#xff09;以及编译耗时长但输出代码优化质量也更高的服务端编译器&#xff08;简称为C2&#xff09;&#xff0c;通常它们会在分层编译…...

修复电子管

年前在咸鱼捡漏买到了10根1G4G电子管&#xff0c;这是一种直热三极管&#xff0c;非常的少见。买回来的时候所有的灯丝都是通的&#xff0c;卖家说都是新的&#xff0c;库存货&#xff0c;但是外观实在是太糟糕了&#xff0c;看着就像被埋在垃圾场埋了几十年的那种&#xff0c;…...

【Java】反射机制和代理机制

目录一、反射1. 反射概念2. 反射的应用场景3. 反射机制的优缺点4. 反射实战获取 Class 对象的四种方式二、代理机制1. 代理模式2. 静态代理3. 动态代理3.1 JDK动态代理机制1. 介绍2.JDK 动态代理类使用步骤3. 代码示例3.2 CGLIB 动态代理机制1.介绍2.CGLIB 动态代理类使用步骤3…...

synchronized底层

Monitor概念一、Java对象头二、Monitor2.1、Monitor—工作原理2.2、Monitor工作原理—字节码角度2.2、synchronized进阶原理&#xff08;优化&#xff09;2.3、synchronized优化原理——轻量级锁2.4、synchronized优化原理——锁膨胀2.5、synchronized优化原理——自旋优化2.6、…...

数据结构:复杂度的练习(笔记)

数据结构&#xff1a;复杂度的练习&#xff08;笔记&#xff09; 例题一&#xff1a; 可以先给数组排序&#xff0c;然后再创建一个i值&#xff0c;让他循环一次一次&#xff0c;遍历这个排序后的数组&#xff0c;但如果用qsort函数进行排序&#xff0c;时间复杂度就和题目要求…...

JAVA练习69- 从前序与中序遍历序列构造二叉树

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 3月5日练习内容 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 一、题目-从…...

brew安装问题

最近使用mac安装了Python和PyCharm&#xff0c;使用python中的绘制图像的turtle库后&#xff0c;执行报错&#xff1a; import _tkinter # If this fails your Python may not be configured for Tk ModuleNotFoundError: No module named _tkinter 查询后需在mac 命令行执行&…...

【数据挖掘与商务智能决策】第一章 数据分析与三重工具

numpy基础 numpy与数组 import numpy as np # 用np代替numpy,让代码更简洁 a [1, 2, 3, 4] # 创建列表a b np.array([1, 2, 3, 4]) #从列表ach print(a) print(b) print(type(a)) #打印a类型 print(type(b)) #打印b类型[1, 2, 3, 4] [1 2 3 4] <class ‘list’>…...

计算机底层:BDC码

计算机底层&#xff1a;BDC码 BDC码的作用&#xff1a; 人类喜欢十进制&#xff0c;而机器适合二进制&#xff0c;因此当机器要翻译二进制给人看时&#xff0c;就会进行二进制和十进制的转换&#xff0c;而常规的转换法&#xff08;k*位权&#xff09;太麻烦。因此就出现了不同…...

【C++】平衡二叉搜索(AVL)树的模拟实现

一、 AVL树的概念 map、multimap、set、multiset 在其文档介绍中可以发现&#xff0c;这几个容器有个共同点是&#xff1a;其底层都是按照二叉搜索树来实现的&#xff0c;但是二叉搜索树有其自身的缺陷&#xff0c;假如往树中插入的元素有序或者接近有序&#xff0c;二叉搜索树…...

[2019红帽杯]childRE

题目下载&#xff1a;下载 参考&#xff1a;re学习笔记&#xff08;24&#xff09;BUUCTF-re-[2019红帽杯]childRE_Forgo7ten的博客-CSDN博客 这道题涉及到c函数的修饰规则&#xff0c;按照规则来看应该是比较容易理解的。上面博客中有总结规则&#xff0c;可以学习一下。 载…...

2D图像处理:九点标定_下(机械手轴线与法兰轴线不重合)(附源码)

文章目录 2. 机械手轴线与法兰轴线不重合2.1 两次拍照避免标定旋转中心2.2 旋转中心标定2.3 非标定中心的方法2.3.1 预备内容-点坐标旋转计算2.3.2 工件存在平移和旋转3. 代码(待更新)上一篇:2D图像处理:九点标定_上(机械手轴线与法兰轴线重合)(附源码) 2. 机械手轴线…...

【二分查找】分巧克力、机器人跳跃、数的范围

Halo&#xff0c;这里是Ppeua。平时主要更新C语言&#xff0c;C&#xff0c;数据结构算法......感兴趣就关注我吧&#xff01;你定不会失望。 &#x1f308;个人主页&#xff1a;主页链接 &#x1f308;算法专栏&#xff1a;专栏链接 我会一直往里填充内容哒&#xff01; &…...

Hyperf使用RabbitMQ消息队列

Hyperf连接使用RabbitMQ消息中间件 传送门 使用Docker部署RabbitMQ&#xff0c;->传送门<使用Docker部署Hyperf&#xff0c;->传送门-< 部署环境 安装amqp扩展 composer require hyperf/amqp安装command命令行扩展 composer require hyperf/command配置参数 假…...

【Linux】P3 用户与用户组

用户与用户组root 超级管理员设置超级管理员密码切换到超级管理员sudo 临时使用超级权限用户与用户组用户组管理用户管理getentroot 超级管理员 设置超级管理员密码 登陆后不会自动开启 root 访问权限&#xff0c;需要首先执行如下步骤设定 root 超级管理员密码 1、解除 roo…...

Spring核心模块——Aware接口

Aware接口前言基本内容例子结尾前言 Spring的依赖注入最大亮点是所有的Bean对Spring容器对存在都是没有意识到&#xff0c;Spring容器中的Bean的耦合度是很低的&#xff0c;我们可以将Spring容器很容易换成其他的容器。 但是实际开发的时候&#xff0c;我们经常要用到Spring容…...

Linux网络编程 第六天

目录 学习目标 libevent介绍 libevent的安装 libevent库的使用 libevent的使用 libevent的地基-event_base 等待事件产生-循环等待event_loop 使用libevent库的步骤&#xff1a; 事件驱动-event 编写一个基于event实现的tcp服务器&#xff1a; 自带buffer的事件-buff…...

STM32开发(六)STM32F103 通信 —— RS485 Modbus通信编程详解

文章目录一、基础知识点二、开发环境三、STM32CubeMX相关配置1、STM32CubeMX基本配置2、STM32CubeMX RS485 相关配置四、Vscode代码讲解五、结果演示以及报文解析一、基础知识点 了解 RS485 Modbus协议技术 。本实验是基于STM32F103开发 实现 通过RS-485实现modbus协议。 准备…...

css实现圆环展示百分比,根据值动态展示所占比例

代码如下 <view class""><view class"circle-chart"><view v-if"!!num" class"pie-item" :style"{background: conic-gradient(var(--one-color) 0%,#E9E6F1 ${num}%),}"></view><view v-else …...

论文笔记——相干体技术在裂缝预测中的应用研究

目录 相关地震知识补充地震数据的认识地震几何属性 相干体算法定义基本原理第一代相干体技术&#xff1a;基于互相关的相干体技术&#xff08;Correlation&#xff09;第二代相干体技术&#xff1a;基于相似的相干体技术&#xff08;Semblance&#xff09;基于多道相似的相干体…...

保姆级教程:在无网络无显卡的Windows电脑的vscode本地部署deepseek

文章目录 1 前言2 部署流程2.1 准备工作2.2 Ollama2.2.1 使用有网络的电脑下载Ollama2.2.2 安装Ollama&#xff08;有网络的电脑&#xff09;2.2.3 安装Ollama&#xff08;无网络的电脑&#xff09;2.2.4 安装验证2.2.5 修改大模型安装位置2.2.6 下载Deepseek模型 2.3 将deepse…...

nnUNet V2修改网络——暴力替换网络为UNet++

更换前,要用nnUNet V2跑通所用数据集,证明nnUNet V2、数据集、运行环境等没有问题 阅读nnU-Net V2 的 U-Net结构,初步了解要修改的网络,知己知彼,修改起来才能游刃有余。 U-Net存在两个局限,一是网络的最佳深度因应用场景而异,这取决于任务的难度和可用于训练的标注数…...

动态规划-1035.不相交的线-力扣(LeetCode)

一、题目解析 光看题目要求和例图&#xff0c;感觉这题好麻烦&#xff0c;直线不能相交啊&#xff0c;每个数字只属于一条连线啊等等&#xff0c;但我们结合题目所给的信息和例图的内容&#xff0c;这不就是最长公共子序列吗&#xff1f;&#xff0c;我们把最长公共子序列连线起…...

ZYNQ学习记录FPGA(二)Verilog语言

一、Verilog简介 1.1 HDL&#xff08;Hardware Description language&#xff09; 在解释HDL之前&#xff0c;先来了解一下数字系统设计的流程&#xff1a;逻辑设计 -> 电路实现 -> 系统验证。 逻辑设计又称前端&#xff0c;在这个过程中就需要用到HDL&#xff0c;正文…...

C++中vector类型的介绍和使用

文章目录 一、vector 类型的简介1.1 基本介绍1.2 常见用法示例1.3 常见成员函数简表 二、vector 数据的插入2.1 push_back() —— 在尾部插入一个元素2.2 emplace_back() —— 在尾部“就地”构造对象2.3 insert() —— 在任意位置插入一个或多个元素2.4 emplace() —— 在任意…...

智警杯备赛--excel模块

数据透视与图表制作 创建步骤 创建 1.在Excel的插入或者数据标签页下找到数据透视表的按钮 2.将数据放进“请选择单元格区域“中&#xff0c;点击确定 这是最终结果&#xff0c;但是由于环境启不了&#xff0c;这里用的是自己的excel&#xff0c;真实的环境中的excel根据实训…...

21-Oracle 23 ai-Automatic SQL Plan Management(SPM)

小伙伴们&#xff0c;有没有迁移数据库完毕后或是突然某一天在同一个实例上同样的SQL&#xff0c; 性能不一样了、业务反馈卡顿、业务超时等各种匪夷所思的现状。 于是SPM定位开始&#xff0c;OCM考试中SPM必考。 其他的AWR、ASH、SQLHC、SQLT、SQL profile等换作下一个话题…...

生成对抗网络(GAN)损失函数解读

GAN损失函数的形式&#xff1a; 以下是对每个部分的解读&#xff1a; 1. ⁡, ​ &#xff1a;这个部分表示生成器&#xff08;Generator&#xff09;G的目标是最小化损失函数。 &#xff1a;判别器&#xff08;Discriminator&#xff09;D的目标是最大化损失函数。 GAN的训…...