1.方法详解
2.方法所属性
3.方法参数传递机制
4.方法多变参数
方法详解
方法是类或对象的行为特征的抽象,方法是类或对象最重要的组成部分。但从功能上来看,方法完全类似于传统结构化程序设计里的函数。值得指出的是,Java里的方法不能独立存在,所有的方法都必须定义在类里。方法在逻辑上要么属于类,要么属于对象。
方法所属性
不论是从定义方法的语法来看,还是从方法的功能来看,都不难发现方法和函数之间的相似性。实际上,方法确实是由传统的函数发展而来的,方法与传统的函数有着显著不同:在结构化编程语言里,函数是一等公民,整个软件由一个个的函数组成;在面向对象编程语言里,类才是一等公民,整个系统由一个个的类组成。因此在Java语言里,方法不能独立存在,方法必须属于类或对象。
因此,如果需要定义方法,则只能在类体内定义,不能独立定义一个方法。一旦将一个方法定义在某个类内,如果这个方法使用了static修饰,则这个方法属于这个类,否则这个方法属于这个类的实例。
Java语言是静态的。一个类定义完成后,只要不再重新编译这个类文件,该类和该类的对象所拥有的方法是固定的,永远都不会改变。
Java里的方法不能独立存在,它必须属于一个类或一个对象,因此方法也不能像函数那样被独立执行,执行方法时必须使用类或对象来作为调用者,即所有方法都必须使用“类.方法”或“对象.方法”的形式来调用。这里可能产生一个问题:同一个类里不同方法之间相互调用时,不就可以直接调用吗?这里需要指出:同一个类的一个方法调用另外一个方法时,如果被调用方法是普通方法,则默认使用this作为调用者;如果调用者是静态方法,则默认使用类作为调用者。也就是说,表面上看起来某些方法可以被独立执行,但实际上还是使用this或者类来作为调用者。
永远不要把方法当初独立存在的实体,正如现实世界由类和对象组成,而方法只能作为类和对象的附属,Java语言里的方法也是一样。Java语言里方法的所属性主要体现在如下几个方面:
- 方法不能独立定义,方法只能在类体里定义
- 从逻辑意义上来看,方法要么属于该类本身,要么属于该类的一个对象。
- 永远不能独立执行方法,执行方法必须使用类或对象作为调用者。
使用static修饰的方法属于这个类本身,使用static修饰的方法即可以使用类作为调用者来调用,也可以使用对象作为调用者来调用。但值得指出的是,因为使用static修饰的方法还是属于这个类的,因此使用该类的任何对象来调用这个方法时将会得到相同的执行结果,因为实际上还是使用这些实例所属的类作为调用者。
没有static修饰的方法则属于该类的对象,不属于这个类本身。因此没有static修饰的方法只能使用对象作为调用者调用,不能使用类作为调用者调用。
方法参数传递机制
前面已经介绍了Java里的方法是不能独立存在的,调用方法必须使用类或对象作为主调用者。如果声明方法时包含了形参声明,则调用方法时必须给这些形参指定参数值,调用方法时实际传给形参的参数值也被称为实参。
那么,Java的实参值时如何传入方法的呢?这是由Java方法的参数传递机制来控制的,Java里方法的参数传递方式只有一种:值传递。所谓值传递,就是将实际参数值的副本(复制品)传入方法内,而参数本身不会受到任何影响。
Java里的参数传递类似于《西游记》里的孙悟空,孙悟空复制出一个假孙悟空,这个假孙悟空具有和真孙悟空相同的能力,可打怪或除妖。但不管这个假孙悟空身上发生了什么事情,真孙悟空不会受到任何影响。与此类似,传入方法的是实际参数值的复制品,不管方法中对这个复制品如何操作,实际参数值本身不会受到任何影响。
发福利:
public static void swap(int a, int b) {
int temp = a;
a = b;
b = temp;
System.out.println("swap---->" + "a = " + a + ", b = " + b);
}
public static void main(String[] args) {
int a = 1, b = 2;
swap(a, b);
System.out.println("main---->" + "a = " + a + ", b = " + b);
}
//打印结果:
//swap---->a = 2, b = 1
//main---->a = 1, b = 2
从上面运行结果来看,swap方法里a和b的值是2、1,交换结束后,变量a和b的值依然是1、2.从这个运行结果可以看出,main方法里的a和b,并不是swap方法里的a和b。正如前面讲的swap方法的a和b只是意图来说明上面程序的执行过程。
形参个数可变方法
从JDK 1.5之后,Java允许定义形参个数可变的参数,从而允许方法指定数量不确定的类型后增加三点( ... ),则表明该形参可以接受多个参数值,多个参数值被当成数组传入。下面程序定义了一个形参个数可以接受多个参数值,多个参数值被当成数组传入。下面程序定义了一个形参个数可变的方法。
发福利:
public static void main(String[] args) {
test(0, "s1", "s2");
}
// 定义了形参个数可变的方法
public static void test(int a, String... strings) {
for (String s : strings) {
// strings被当成数组处理
System.out.println("形参之一---->" + s);
}
System.out.println("普通参数---->" + a);
}
// 控制打印结果
// 形参之一---->s1
// 形参之一---->s2
// 普通参数---->0
从上面运行结果可以看出,当调用test方法时,strings形参可以传入多个字符串作为参数值。从test的方法体代码来看,形参个数可变的参数其实就是一个数组参数,也就是说,下面两个方法签名的效果完全一样。
// 以可变个数形参定义方法
public static void test(int a, String... strings) {}
// 以数组形参定义方法
public static void test(int a, String[] strings){}
这两种形式都包含了一个名为strings的形参,在两个方法的方法体内都可以把strings当成数组处理。但区别是调用两个方法时存在差别,对于以可变形参的形式定义的方法,调用方法时更加简洁,如下面代码所示。
test(0,"s1","s2"){}
传给strings参数的实参数值无需是一个数组,但如果使用数组形参来声明方法,调用时则必须给该形参一个数组,如下所示。
test(0,new String[]{"s1","s2"}
对比两种调用test方法的代码,明显第一种形式更加简洁。实际上,即使是采用形参个数可变的形式来定义方法,调用该方法时也一样可以为个数可变的形参传入一个数组。
最后还要指出的是,数组形式的形参可以出现在参数列表的任意位置,但个数可变的形参只能处于形参列表的最后。也就是说,一个方法中最多只能又一个长度可变的形参。
长度可变的形参只能处于形参列表的最后。一个方法中最多只能包含一个长度可变的形参。调用包含一个长度可变形参的方法时,这个长度可变的形参即可以传入多个参数,也可以传入一个数组。
喜欢有帮助的话: 双击、评论、转发,动一动你的小手让更多的人知道!关注 帅比-杨
摘自:李刚〔疯狂java〕