。如下面是一个普通的Java类:lassTest//从Object类继承{publicstaticvoidmain(String[]args){(newTest().toString());}}从上面的代码可以看出,实际上,Test类的父类就是Object,因此,在Test中可以使用Object类的public或protected资源,如toString方法。那么Java编译器和JVM到底是如何做的呢,了解这个原因其实并不需要知道JVM的实现细节。只要思考一下对于这种虚拟机程序的原理即可。一般对于这种靠虚拟机运行的语言(如Java、C#等)会有两种方法处理默认继承问题。,当遇到没有父类的类时,编译器会将其指定一个默认的父类(一般为Object),而虚拟机在处理到这个类时,由于这个类已经有一个默认的父类了,因此,VM仍然会按着常规的方法来处理每一个类。对于这种情况,从编译后的二进制角度来看,所有的类都会有一个父类。,并不会做额外的处理。如果一个类没有显式地继承于其他的类,编译后的代码仍然没有父类。然后由虚拟机运行二进制代码时,当遇到没有父类的类时,就会自动将这个类看成是Object类的子类(一般这类语言的默认父类都是Object)。从上面两种情况可以看出,第1种情况是在编译器上做的文章,也就是说,当没有父类时,由编译器在编译时自动为其指定一个父类。第2种情况是在虚拟机上做文章,也就是这个默认的父类是由虚拟机来添加的。那么Java是属性哪一种情况呢,其实这个答案很好得出。只需要随便找一个反编译工具,。就以上面代码为例,如果是第1种情况,就算Test没有父类,但由于编译器已经为Test自动添加了一个Object父类,因此,在反编译后得到的源代码中的Test类是从Object类继承的。如果没是这种情况,那么就是第2种情况。,先执行下面的命令:javapTest>,会看到如下的代码:{publicTest();publicstaticvoidmain([]);}再使用下面的命令来得到bytecode代码:javap-cTest>,会看到如下的代码:{publicTest();Code:0:aload_01:invokespecial#8;//Methodjava/lang/Object."<init>":()V4:returnpublicstaticvoidmain([]);Code:0:getstatic#16;//Fieldjava/lang/:Ljava/io/PrintStream;3:new#1;//classTest6:dup7:
object是所有类的父类 来自淘豆网www.taodocs.com转载请标明出处.