文章
时间轴
标签
音乐室
友人帐
一刻时光
清单
留言板
相册
算法海洋
关于
Slcpの童话镇 🏰
写文章
Java基础知识及细节之方法
原创
Java
后端
发布日期:
2019年07月05日
文章字数:
5.1k
阅读次数:
946
阅读时长:
0小时0分0秒
## 方法 ### 方法概述 方法(method)是具有独立功能的代码块。 优点:`减少了代码的重复,提升了代码的复用性。` 缺点:降低了程序的执行效率。 **注意事项** `方法必须先创建才可以使用`,该过程称方法的定义。 `方法创建后并不能直接运行,需要手动调用后才执行`,该过程称方法的调用。 ### 方法的定义和调用 * 定义方法的小技巧:三个明确。 * 明确方法要做什么? * 明确方法的参数? 该方法在执行的时候是否需要有数据参与操作 * 明确方法的返回值? 该方法执行完之后,是否返回一个结果。 #### 无参数方法的定义和调用(掌握) * 定义格式: ~~~java public static void 方法名() { //方法体; } ~~~ * 范例: ~~~java public static void sum() { //定义变量 int a = 10, b = 20; //计算并输出和 System.out.println(a + b); } ~~~ * 调用格式: ```java 方法名(); ``` * 范例: ~~~java sum(); ~~~ **注意事项:**`方法必须先定义再调用,不然程序会报错。` #### 方法的调用过程(理解) * 总结:每个方法在被调用执行的时候,都会进入栈内存,并且拥有自己独立的内存空间,方法内部代码调用完毕之后,会从栈内存中弹栈消失。 #### 方法练习-奇偶数判断(应用) * 需求:定义一个方法,在方法中定义一个变量,判断该数据是否是偶数 * 代码: ```java /** * @Author: ✎﹏ Sunflower丶 */ public class Demo01 { /* 定义一个方法,在方法中定义一个变量,判断该数据是否是偶数 */ public static void main(String[] args) { a(); } public static void a() { //创建键盘录入对象 Scanner sc = new Scanner(System.in); //判断是否有整数录入 if (sc.hasNextInt()) { //记录录入整数 int num = sc.nextInt(); //判断num是否整除2 if (num % 2 == 0) { System.out.println(num + "是偶数"); }else { System.out.println(num + "不是偶数"); } } } } ``` ### 带参数方法的定义和调用 #### 带参数方法的定义和调用(掌握) * 定义格式: ~~~java public static void 方法名(参数) { //方法体 } public static void 方法名(参数1,参数2,...参数n) { //方法体 } ~~~ * 范例: ~~~java public static void num(int a) { System.out.println(a); } public static void sum(int a, int b) { //计算a+b int c = a + b; //输出和 System.out.println(c); } ~~~ * 调用格式: ~~~java 方法名(参数); 方法名(参数1,参数2...参数n); ~~~ * 范例: ~~~java num(10); sum(10,20); ~~~ **注意事项:** `1.在方法定义时,参数中的数据类型和变量名缺一不可,缺少一个程序就会报错` `2.在方法定义时,多个参数之间使用逗号(,)分隔开来` `3.在调用方法时,参数与类型必须与方法定义中的设置相匹配,不然程序会报错` #### 形参与实参(理解) 1. 形参:形式参数,没有明确的值。一般为方法定义中的参数。 2. 实参:实际参数,有明确的值。方法调用的参数,也就是真实的值。 #### 带参数方法的练习-打印n-m之间所有的奇数(应用) * 需求:设计一个方法(print) 用于打印 n 到 m 之间所有的奇数 * 思路: 1:定义方法,名称为print 2:为方法添加两个int类型的形参,准备接受调用者传递过来的实参 3:方法中设计for循环,循环从n开始,到m结束 4:循环中加入if判断,是奇数,则打印 5:main方法中调用print方法,传入两个实际参数 * 代码: ~~~java /** * @Author: ✎﹏ Sunflower丶 */ public class Demo02 { public static void main(String[] args) { // 5:main方法中调用print方法,传入两个实际参数 print(20,10); } //1:定义方法,名称为print // 2:为方法添加两个int类型的形参,准备接受调用者传递过来的实参 public static void print(int n, int m){ System.out.println(n + "到" + m + "之间的奇数为:"); // 3:方法中设计for循环,循环从n开始,到m结束 for(int i = 20; i <= 10; i++){ // 4:循环中加入if判断,是奇数,则打印 if(i % 2 == 1){ System.out.println(i); } } } } ~~~ ### 可变参数 #### 可变参数概念(理解) * JDK1.5开始,Java支持传递同类型的可变参数给一个方法。 * 在方法声明中,在指定参数类型后加一个省略号(...)。 * `一个方法中只能一个可变参数,它必须是方法的最后一个参数。任何普通的参数必须在它之前声明。` 定义格式: ~~~ java public static 数据类型 方法名 ( 数据类型...数组名 ) { return 数据 ; } ~~~ 范例: ~~~java public static boolean isEvenNumber( int...number ) { return true ; } public static int getMax( int a, int...b ) { return 100 ; } ~~~ #### 可变参数练习-排序算法(应用) 需求:创建一个方法,可以输出数组的最大值。 代码: ~~~java /** * @Author: ✎﹏ Sunflower丶 */ public class Demo03 { /* 可变参数,排序算法 */ public static void main(String[] args) { Demo02 d = new Demo02(); //单个输入 d.max(20, 80, 70.0, 43, 68); //输入数组 d.max(new double[] {30, 50, 60}); } //定义可变参数方法,并计算可变参数的最大值 public void max(double...grade) { //记录最大值 double max = 0; //将记录的max与传入的可变参数依次进行比较 for (double v : grade) { //如果max小于可变参数的某个值,那么就将其赋值给max if (max < v) { max = v; } } //输出max System.out.println(max); } } ~~~ **注意事项** `1.在调用方法的时候,传入参数的范围满足可自动类型提升为方法定义中的参数类型` `2.在调用方法的时候,传参可以是单个的数据,也可以是数组` ### 带返回值方法的定义和调用 #### 带返回值方法定义和调用(掌握) * 定义格式 ```java public static 数据类型 方法名 ( 参数 ) { return 数据 ; } ``` * 范例 ```java public static boolean isEvenNumber( int number ) { return true ; } public static int getMax( int a, int b ) { return 100 ; } ``` * 调用格式 ```java 方法名 ( 参数 ) ; 数据类型 变量名 = 方法名 ( 参数 ) ; ``` * 范例 ```java isEvenNumber ( 5 ) ; boolean flag = isEvenNumber ( 5 ); ``` 调用方式:`直接调用(无意义,一般是用于没有返回值void的方法调用),赋值调用(项目常用),输出调用(只供学习使用)` **注意事项:** `1.方法定义时return后面的返回值与方法定义上的数据类型要匹配,否则程序将报错` `2.方法的返回值只能是一个结果,多个则程序报错` `3.方法的返回值通常会使用变量接收,否则该返回值将无意义` #### 带返回值方法的练习-求两个数的最大值(应用) * 需求:设计一个方法可以获取两个数的较大值,数据来自于参数 * 思路: 1. 定义一个方法,声明两个形参接收计算的数值,求出结果并返回 2. 使用 if 语句 得出 a 和 b 之间的最大值,根据情况return具体结果 3. 在main()方法中调用定义好的方法并使用 【 变量保存 】 * 代码: ~~~java /** * @Author: ✎﹏ Sunflower丶 */ public static void main(String[] args) { // 在main()方法中调用定义好的方法并使用 【 变量保存 】 System.out.println(getMax(10,20)); // 输出调用 int result = getMax(10,20); System.out.println(result); for(int i = 1; i <= result; i++){ System.out.println("HelloWorld"); } } // 方法可以获取两个数的较大值 public static int getMax(int a, int b){ if(a > b){ return a; }else{ return b; } } } ~~~ ### 方法的重载 #### 方法的重载 * 方法重载概念 方法重载指同一个类中定义的多个方法之间的关系,满足下列条件的多个方法相互构成重载 * 多个方法在同一个类中 * 多个方法具有相同的方法名 * 多个方法的参数不相同,类型不同或者数量不同 * 简单理解:在同一个类中,方法名相同,参数不同。与返回值类型无关 * 参数不同 * 参数个数不同 * 参数类型不同 * 参数排列顺序不同 **注意事项** `1.方法必须在同一个类中,才会出现重载` `2.方法与方法之间必须满足要求才会出现重载` `3.重载仅对应方法的定义,与方法的调用无关,调用方式参照标准格式` `4.重载仅针对同一个类中方法的名称与参数进行识别,与返回值无关,换句话说不能通过返回值来判定两个方法是否相互构成重载` #### 方法重载练习 * 需求:使用方法重载的思想,设计比较两个整数是否相同的方法,兼容全整数类型(byte,short,int,long) * 思路: ①定义比较两个数字的是否相同的方法compare()方法,参数选择两个int型参数 ②定义对应的重载方法,变更对应的参数类型,参数变更为两个long型参数 ③定义所有的重载方法,两个byte类型与两个short类型参数 ④完成方法的调用,测试运行结果 * 代码: ~~~java public class MethodTest { public static void main(String[] args) { //调用方法 System.out.println(compare(10, 20)); System.out.println(compare((byte) 10, (byte) 20)); System.out.println(compare((short) 10, (short) 20)); System.out.println(compare(10L, 20L)); } //int public static boolean compare(int a, int b) { System.out.println("int"); return a == b; } //byte public static boolean compare(byte a, byte b) { System.out.println("byte"); return a == b; } //short public static boolean compare(short a, short b) { System.out.println("short"); return a == b; } //long public static boolean compare(long a, long b) { System.out.println("long"); return a == b; } } ~~~ ### 方法的参数传递 #### 方法参数传递基本类型(理解) * 测试代码: ```java package com.itheima.param; public class Test1 { /* 方法参数传递为基本数据类型 : 传入方法中的, 是具体的数值. */ public static void main(String[] args) { int number = 100; System.out.println("调用change方法前:" + number); change(number); System.out.println("调用change方法后:" + number); } public static void change(int number) { number = 200; } } ``` * 结论: * 基本数据类型的参数,形式参数的改变,不影响实际参数 * 结论依据: * 每个方法在栈内存中,都会有独立的栈空间,方法运行结束后就会弹栈消失 #### 方法参数传递引用类型 * 测试代码: ```java package com.itheima.param; public class Test2 { /* 方法参数传递为引用数据类型 : 传入方法中的, 是内存地址. */ public static void main(String[] args) { int[] arr = {10, 20, 30}; System.out.println("调用change方法前:" + arr[1]); change(arr); System.out.println("调用change方法后:" + arr[1]); } public static void change(int[] arr) { arr[1] = 200; } } ``` * 结论: * 对于引用类型的参数,形式参数的改变,影响实际参数的值 * 结论依据: * 引用数据类型的传参,传入的是地址值,内存中会造成两个引用指向同一个内存的效果,所以即使方法弹栈,堆内存中的数据也已经是改变后的结果
您阅读这篇文章共耗时:
0小时16分34秒
文章链接:
https://www.slcp.top/article/read/19
版权声明:
本博客所有文章除特別声明外,均采用
CC BY 4.0
许可协议。转载请注明来源
Slcp
!
转载文章以及部分引用均为自己整理记录学习而用,若有侵权,请联系删除。
Java
评论
Valine
Gitalk
目录
搜索
首页
前进
后退
刷新
申请友链
在线联系