ClassLoader:
将class文件加载到虚拟机、生成累的Class对象jvm启动的时候,并不会一次性加载所有的class文件,而是根据需要去动态加载。
自定义ClassLoader:
不管是Bootstrap ClassLoader还是ExtClassLoader等,这些类加载器都只是加载指定的目录下的jar包或者资源。如果在某种情况下,我们需要动态加载一些东西呢?比如从D盘某个文件夹加载一个class文件,或者从网络上下载class主内容然后再进行加载,这样可以吗?
自定义步骤:
- 编写一个类继承自ClassLoader抽象类。
- 复写它的findClass()方法。
- 在findClass()方法中调用defineClass()。
class.forName()和classLoader区别:
class.forName()前者除了将类的.class文件加载到jvm中之外,还会对类进行解释,执行类中的static块。
classLoader只干一件事情,就是将.class文件加载到jvm中,不会执行static中的内容,只有在newInstance才会去执行static块。
数据库链接为什么使用Class.forName(className):
使用Class.forName(classname),执行以下代码:
static {
try {
java.sql.DriverManager.registerDriver(new Driver());
} catch (SQLException E) {
throw new RuntimeException("Can't register driver!");
}
}
new与class.forName().newInstance()区别:
A a = (A)Class.forName(“pacage.A”).newInstance()
与A a = newA()是一样的效果。newInstance()方法和new关键字:
1、创建对象的方式不一样,前者是使用类加载机制,后者是创建一个新类
2、newInstance()方法它生成对象只能调用无参的构造函数,而使用 new关键字生成对象没有这个限制。
3、new返回的是类,而Class.forName(“”).newInstance()返回的是object
获取类的Class对象:
1、对象.getClass()
2、类名.class
3、Class.forName(“”)
Class.forName(“”).newInstance()实际上是把new这个方式分解为两步,即首先调用Class加载方法加载某个类,然后实例化。
这样分步的好处是显而易见的。我们可以在调用class的静态加载方法forName时获得更好的灵活性,提供给了一种降耦的手段。