你对JAVA静态载入了解吗?如果你了解,你了解多少呢?下面就为你介绍JAVA的静态载入。
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类加载器中的称号空间是***的, 不会相互搅扰。
即在一般情况下, 保证同一个类中所关联的其他类都是由以后类的类加载器所加载的。
以下是代码片段:
- public static Class forName(String className)
- throws ClassNotFoundException {
- return forName0(className, true , ClassLoader. getCallerClassLoader());
- }
- /** Called after security checks have been made. */
- private static native Class forName0(String name, boolean initialize,
- ClassLoader loader)
- throws ClassNotFoundException; Java代码
- public static Class forName(String className)
- throws ClassNotFoundException {
- return forName0(className, true , ClassLoader. getCallerClassLoader());
- }
- /** Called after security checks have been made. */
- private static native Class forName0(String name, boolean initialize,
- ClassLoader loader)
- 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静态载入的介绍,希望对你有帮助。
【编辑推荐】