- 方法调用不是方法执行,只是确定调用哪个方法,和C不一样的是,class文件的编译过程不包含连接(link),一切方法调用都只是符号引用,而不是直接引用(方法在实际运行时内存布局中的入口地址),需要在类加载期间甚至运行期间才能确定目标方法的直接引用,就是因为这个特性,java具有很强大的扩展能力
- 在类加载期间解析的方法是满足”编译期可知,运行期不可变“条件的方法,也就是静态方法和私有方法,前者与类型直接关联,后者在外部无法被访问,都是不能通过继承重写出其他版本的方法,这些方法在类装载的时候就会把符号引用转变成直接引用,而不是等到运行期再去完成
- 在方法重载的时候编译器如何识别用户调用的是哪个方法?其实编译器它自己都不知道,只是找一个比较接近的方法,如:
public void hello(Object a) {
System.out.println("object");
}
public void hello(int a) {
System.out.println("int");
}
public void hello(Integer a) {
System.out.println("Integer");
}
public void hello(long a) {
System.out.println("long");
}
public void hello(Long a) {
System.out.println("Long");
}
public void hello(char a) {
System.out.println("char");
}
public void hello(Character a) {
System.out.println("Character");
}
public void hello(char... a) {
System.out.println("char...");
}
public void hello(Character... a) {
System.out.println("Character...");
}
public void hello(Serializable a) {
System.out.println("Serializable");
}
public static void main(String[] args) {
test t = new test();
t.hello('a');
}
这个输出的是
char
注释掉char的方法,输出
int
后面同理,分别输出long,Character,Serializable,object,把object注释掉后就报错了