ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、视频、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
## 1.对抽象、继承、多态的理解 ## 2.泛型的作用及使用场景 ## 3.枚举的特点及使用场景 ## 4.线程sleep和wait的区别 ## 5.JAVA反射机制 总结:在程序运行时通过类类型Class获得目标类的信息,然后在类信息的基础上使用相对应的类加载器加载到内存中,再然后对这个类中进行实例化,方法调用等的使用的整个过程。 > Java可以在运行时加载、探知、使用编译期间完全未知的class。 Java可以在运行时获得任意一个类的信息(包括它的基类、所实现的接口、方法等)、构建类的Class对象(不是该类的对象,是后面提高的类类型)、生成类实例、调用methods。 > RTTI(Run-Time Type Information,运行时类型信息), 即程序在运行时去获得一个对象所对应的类的信息。 > 类类型java.lang.Class: Class是所有类和接口的抽象,比如类的名字、类实现的接口、方法、属性等。可以通知某个对象的Class对象来获取类的信息。 > Class loader 类加载的过程就是将.class加载到内存中。 反射过程中使用到了Classloader,并且不同的类需要相对应的Classloader来加载。 Classloader是负责加载类的对象,作用是根据Jvm请求提供的类信息,将请求的类加载到内存中或加载到Jvm中。 每一个类的Class对象都持有一个对应的Classloader的引用,可以通过Class对象的getClassLoader()方法得到。 #### Java的Classloader有四种,分别为: 1. bootstrap Classloader:引导类加载器; 是用C++编写的,是JVM的内置类加载器,它的名字为null。它用来加载核心类库,即在lib下的类库。 2. extension Classloader:扩展类加载器; 加载lib/ext下的类库。 3. Application Classloader:应用程序类加载器; 加载ClassPath里的类库。 4. User Defined Classloader:自定义类加载器。 #### 层次关系: 每一个Class对象都会持有一个对应的ClassLoader的引用。每一个ClassLoader对象也会持有一个Parent ClassLoader的引用。(不是继承,只是引用) Bootstrap ClassLoader <- Extrension ClassLoader <- Application Classloader <- .... #### 双亲加载机制: 即当一个ClassLoader接到请求时,它不是直接加载对应的类,而是询问它引用的ClassLoader是否能够加载,而这个父ClassLoader则会询问自己引用的ClassLoader是否加载了该类。只有当所有的ClassLoader都没有加载该类时,最初的ClassLoader才自己去加载申请的类。 双亲加载机制可以一定程序上保证安全性,因为只要顶层ClassLoader能加载的东西就一定不会让下层的ClassLoader有机会加载。也就保证了有些自定义的带有破坏性的类不会被加载到JVM核心中。 #### Class类类型 Class类是所有类(注意是对象)的共有信息的抽象,比如该类实现的接口、对应的加载器、类名等等。 一句话,每一个类都有一个Class对象,这个对象在类加载后由JVM自动构造,也是由JVM管理的,Class类没有公共的构造方法。 怎么得到Class对象: 1)利用Object.getClass()方法获取该对象的Class实例; 2)利用Class.forName()静态方法,用类的名字获取一个Class实例; 3)运行类的.class的方式来获取Class实例,对于基本数据类型的封装类,还可以采用.TYPE来获取相对应的基本数据类型的Class实例。 注意:虚拟机只会产生一份字节码,用这份字节码可以产生多个实例对象。也就是说Class对象只会有一个。 也就是说,在运行期间,如果我们要产生某个类的对象或者需要得到某个类的Class对象,JVM会检查该类型的Class对象是否已被加载。如果没有被加载,JVM会根据类的名称找到.class文件并加载它。一旦某个类型的Class对象已被加载到内存,就可以用它来产生该类型的所有对象。 ## 6.weak/soft/strong引用的区别 ## 7.Object的hashCode()与equals()的区别和作用 ## 8.内部类,匿名类