何为方法
Java方法是语句的集合,他们在一起执行一个功能
方法是解决一类问题的步骤有序组合 方法包含与类或对象中 方法在程序中被创建,在其他地方被引用 设计方法的原则:方法的本意是功能块,就是实现某个功能的语句块的集合,我们设计方法的时候最好保持方法的原子性:就是一个方法只能完成1个功能,这样有利于我们以后的扩展 方法的命名规则:第一个单词开头小写后跟驼峰原则
方法的定义及调用
public static void main ( String [ ] args) {
add ( 10 , 20 ) ;
}
public static void add ( int a, int b) {
System . out. println ( a+ b) ;
}
方法重载
重载就是在一个类中,有相同的函数名称,但形参不同的函数 方法的重载规则
方法名称必须相同 参数列表必须不同(个数不同,类型不同,参数排列顺序不同等) 方法的返回类型可以相同也可以不同 仅仅返回值不同不足以成为方法的重载 现实理论
方法名称相同时,编译器会通过调用方法的参数个数,参数类型等去逐个匹配,以选择对应的方法,如果匹配失败,则编译器会报错
public static void add ( int a, int b) {
System . out. println ( a+ b) ;
}
public static void add ( double a, double b) {
System . out. println ( a+ b) ;
}
命令行传参
可变参数
Java支持传递同类型的可变参数给一个方法 在方法声明中,在指定类型后加一个省略号(…):public void add(int... x)
一个方法只能指定一个可变参数,他必须是方法的最后一个参数,任何普通参数都必须在他之前声明
public static void main ( String [ ] args) {
varargs ( 10 , 20 , 30 , 4 , 5 , 6 , 7 , 8 , 9 , 0 ) ;
}
public static void varargs ( int . . . x) {
for ( int i = 0 ; i < x. length; i++ ) {
System . out. print ( x[ i] + "\t" ) ;
}
}
递归
A方法调用B方法,我们很容易理解! 递归就是: A方法调用A方法!就是自己调用自己 利用递归可以用简单的程序来解决- 些复杂的问题。它通常把一一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合。 递归结构包括两个部分:
递归头:什么时候不调用自身方法。如果没有头,将陷入死循环。 递归体:什么时候需要调用自身方法。
public static void main ( String [ ] args) {
System . out. println ( factorial ( 5 ) ) ;
}
public static int factorial ( int x) {
if ( x== 0 ) return 0 ;
if ( x== 1 ) return 1 ;
else return x* factorial ( x- 1 ) ;
}