首页 / JAVA / 030_Java方法
030_Java方法
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了030_Java方法,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2973字,纯文字阅读大概需要5分钟。
内容图文
目录Java方法
https://www.bilibili.com/video/BV12J41137hu/?p=45
方法的定义
- 方法是用来完成特定功能的代码片段。
方法的组成
- 方法头
- 修饰符,定义该方法的访问类型。
- 返回值类型。
- 方法名,方法名和参数类型共同构成方法签名。
- 参数类型。
- 实参:调用方法时传递的参数。
- 形参:方法中的参数,用来定义参数。
- 方法体,定义该方法的功能。
方法的重载
重载就是在一个类中,有相同的函数名称,但形参不同的函数。
方法的重载规则
- 方法名称必须相同。
- 参数列表必须不同(个数不同、类型不同、参数排列顺序不同等)。
- 方法的返回类型可以相同也可以不同。
- 仅仅返回类型不同不足以成为方法的重载。
实现理论
方法名称相同时,编译器会根据调用方法的参数个数、参数类型等去逐个匹配,以选择对应的方法,如果匹配失败,则编译器报错。
命令行传参
package com.qing.method;
public class Demo01 {
public static void main(String[] args) {
for (int i = 0; i < args.length; i++) {
System.out.println("args[" + i + "]: " + args[i]);
}
}
}
D:\code\JavaSE\基础语法\src\com\qing\method>dir
驱动器 D 中的卷没有标签。
卷的序列号是 46DA-BD61
D:\code\JavaSE\基础语法\src\com\qing\method 的目录
2020/10/31 12:43 <DIR> .
2020/10/31 12:43 <DIR> ..
2020/10/31 12:43 231 Demo01.java
1 个文件 231 字节
2 个目录 307,004,313,600 可用字节
D:\code\JavaSE\基础语法\src\com\qing\method>javac Demo01.java
D:\code\JavaSE\基础语法\src\com\qing\method>java Demo01
错误: 找不到或无法加载主类 Demo01
D:\code\JavaSE\基础语法\src\com\qing\method>cd ../../../
D:\code\JavaSE\基础语法\src>java com.qing.method.Demo01
D:\code\JavaSE\基础语法\src>java com.qing.method.Demo01 Hello World
args[0]: Hello
args[1]: World
D:\code\JavaSE\基础语法\src>
可变参数
- JDK1.5开始,Java支持传递同类型的可变参数给一个方法。
- 在方法声明中,在指定参数类型后加一个省略号(...)。
- 一个方法中只能指定一个可变参数,它必须是方法的最后一个参数。任何普通的参数必须在它之前声明。
- 可变参数本质是数组。
package com.qing.method;
public class Demo02 {
public static void main(String[] args) {
new Demo02().printMax();
new Demo02().printMax(7.1, 3, 5);
new Demo02().printMax(new double[]{7.1, 3, 5});
}
//打印最大值
private void printMax(double... numbers) {
if (numbers.length == 0) {
System.out.println("numbers is empty");
return;
}
double max = numbers[0];
for (int i = 1; i < numbers.length; i++) {
if (numbers[i] > max) {
max = numbers[i];
}
}
System.out.println("max: " + max);
}
}
没有传参
max: 7.1
max: 7.1
递归
递归就是自己调用自己。
递归结构
- 递归头:什么时候不调用自身方法。如果没有头,将陷入死循环。
- 递归体:什么时候需要调用自身方法。
最重要的是递归思想。如果深度太大,不介意用递归,会造成内存奔溃。
package com.qing.method;
public class Demo03 {
public static void main(String[] args) {
System.out.println("5! = " + f(5));
System.out.println("4! = " + f(4));
System.out.println("3! = " + f(3));
}
//递归,计算阶乘
//阶乘:n! = n * (n-1) * (n-2)... * 1
private static int f(int n) {
if (n < 1) {
System.out.println("入参不能小于1");
return 0;
}
if (n == 1) {
return 1;
}
return n * f(n - 1);
}
}
5! = 120
4! = 24
3! = 6
内容总结
以上是互联网集市为您收集整理的030_Java方法全部内容,希望文章能够帮你解决030_Java方法所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。