java静态载入的时分需要思索到平安要素, 这个问题就是我们必须处理的问题。 下面我们就看看如何才干更好的处理相关平安上面的问题。 希望大家从中吸取相关的知识。
我们试想一下, 假如不运用这种委托形式, 那我们就可以随时运用自定义的String来静态替代java中心api中定义类型, 这样会存在十分大的平安隐患, 而双亲委托的方式, 就可以防止这种状况, 由于String曾经在启动时被加载, 所以用户自定义类是无法加载一个自定义的ClassLoader。
java静态载入class的两种方式:
implicit隐式, 即利用实例化才载入的特性来java静态载入入class
explicit显式方式, 又分两种方式:
java. lang. Class的forName()方法
java. lang. ClassLoader的loadClass()方法
用Class. forName加载类
Class. forName运用的是被调用者的类加载器来加载类的。
这种特性, 证明了java类加载器中的名称空间是独一的, 不会相互关扰。
即在普通状况下, 保证同一个类中所关联的其他类都是由以后类的类加载器所加载的。
1. public static Class forName(String className)
2. throws ClassNotFoundException {
3. return forName0(className, true , ClassLoader. getCallerClassLoader());
4. }
5. /** Called after security checks have been made. */
6. private static native Class forName0(String name, boolean initialize,
7. ClassLoader loader)
8. throws ClassNotFoundException;
Java代码
9. public static Class forName(String className)
10. throws ClassNotFoundException {
11. return forName0(className, true , ClassLoader. getCallerClassLoader());
12. }
13. /** Called after security checks have been made. */
14. private static native Class forName0(String name, boolean initialize,
15. ClassLoader loader)
16. throws ClassNotFoundException;
上面中 ClassLoader. getCallerClassLoader 就是失掉调用以后forName方法的类的类加载器
static块在什么时分执行?
当调用forName(String)载入class时执行, 假如调用ClassLoader. loadClass并不会执行. forName(String, false, ClassLoader)时也不会执行, 假如载入Class时没有执行static块则在第一次实例化时执行. 比方new , Class. newInstance()操作static块仅执行一次, 各个java类由哪些classLoader加载?
java类可以通过实例. getClass. getClassLoader()得知
接口由AppClassLoader(System ClassLoader, 可以由ClassLoader. getSystemClassLoader()取得实例)载入
ClassLoader类由bootstrap loader载入
NoClassDefFoundError和ClassNotFoundException
NoClassDefFoundError:当java源文件已编译成. class文件, 但是ClassLoader在运转时期在其搜索路径load某个类时, 没有找到. class文件则报这个错
ClassNotFoundException:试图通过一个String变量来创建一个Class类时不成功则抛出这个异常,以上就是对java静态载入的详细引见。文章由
红酒木瓜整理,收集辛苦,希望能保留出处。