Java方法是语句的集合,它们在一起执行一个功能。它类似于其它语言的函数,是一段用来完成特定功能的代码片段。
设计方法的原则:方法的本意是功能块,就是实现某个功能的语句的语句块的集合。我们设计方法的时候,最好保持方法的原子性,就是一个方法只完成一个功能,这样利于我们后期的扩展。
方法包含一个方法头和一个方法体,它的语法如下:
修饰符 返回值类型 方法名(参数类型 参数名){
···
方法体
···
return 返回值;
}
修饰符:这是可选的,告诉编译器如何调用该方法,定义了该方法的访问类型。
返回值类型:方法可能会有返回值。有些方法执行所需的操作,但是没有返回值,在这种情况下,返回值数据类型是关键字void。
方法名:是方法的实际名称,方法名和参数表共同构成方法签名。
参数类型:参数像是一个占位符,当方法被调用时,传递值给参数。这个值被称为实参或变量。参数列表是指方法的参数类型、顺序和参数的个数。参数是可选的,方法可以不包含任何参数。
? 形式参数:在方法被调用时用于接收外界输入的数据。
? 实参:调用方法时实际传给方法的数据。
方法体:方法体包含具体的语句,定义该方法的功能。
调用方法:对象名.方法名(实参列表)
Java支持两种调用方法的方式,根据方法是否返回值来选择。
int larger=max(30,40);
System.out.println("hello,world!")
实例:
package method;
public class maxDemo01 {
public static void main(String[] args) {
//调用max方法
int larger=max(25,25);
System.out.println(larger);
}
//定义一个max方法,取出最大值
public static int max(int a,int b){
int result;
if(a>b){
result=a;
}else{
result=b;
}
return result;
}
}
重载就是在一个类中,有相同的方法名,但形参不同的方法。
方法重载的规则:
package method;
public class maxDemo02 {
public static void main(String[] args) {
double larger=max(12.44,18.94);
System.out.println(larger);
}
public static double max(double a,double b){
int result;
if(a>b){
result=a;
}else{
result=b;
}
return result;
}
public static int max(int a,int b){
int result;
if(a>b){
result=a;
}else{
result=b;
}
return result;
}
}
从JDK1.5开始,Java支持传递同类型的可变参数给一个方法。
在方法声明中,在指定参数类型后加一个省略号(...)。
一个方法中只能指定一个可变参数,它必须是方法的最后一个参数,任何普通的参数必须在它之前声明。
package method;
public class Demo03 {
public static void main(String[] args) {
printMax(3,4,11,45,13,21);
}
public static void printMax(double... numbers){
if(numbers.length==0){
System.out.println("No argument passed.");
return;
}
double result=numbers[0];
//排序
for(int i=0;i<numbers.length;i++) {
if (result <= numbers[i]) {
result = numbers[i];
}
}
System.out.println("The Max value is :");
System.out.println(result);
}
}
递归就是A方法调用A方法,即自己调用自己。
利用递归可以用简单的程序来解决一些复杂的问题。他通常把一个大型复杂的文体层层转化为一个与原问题相似的规模较小的问题来求解,递归只需少量的程序就可以描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量,递归的能力在于用有限的语句来定义对象的无限集合。
递归结构包括两个部分:
递归头:什么时候不调用自身方法,如果没有说明,将陷入死循环;
递归体:什么时候需要调用自身方法;
package method;
public class Demo04 {
public static void main(String[] args) {
System.out.println(f(5));
}
//计算阶乘
public static int f(int n){
if(n==1){
return 1;
}else{
return n*f(n-1);
}
}
}
递归虽然可以将程序简化,但是如果调用自身方法次数太多,是会影响程序性能的!
原文:https://www.cnblogs.com/jane0118/p/13031384.html