java创建对象实例的方法及区别

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_22339457/article/details/82527317

本博客总结了前人的研究,添加了自己的理解

一.创建对象实例的方法
1、类.class.newInstance();
2、Class.forName(类全限定名).newInstance();
3、new 类();

从JVM的角度看,我们使用关键字new创建一个类的时候,这个类可以没有被加载。但是使用newInstance()方法的时候,就必须保证:
1、这个类已经加载;
2、这个类已经连接了。
而完成上面两个步骤的正是Class的静态方法forName()所完成的,这个静态方法调用了类加载器,即加载 java API的那个加载器。

现在可以看出,newInstance()实际上是把new这个方式分解为两步,即首先调用Class加载方法加载某个类,然后实例化。

这样分步的好处是显而易见的。我们可以在调用class的静态加载方法forName时获得更好的灵活性,提供给了一种降耦的手段。

二.new 、Class.forName(1)和newInstanc()有什么区别?
其实上面已经说到一些了,这里来做个总结:
首先,newInstance( )是一个方法,而new是一个关键字;
其次,Class下的newInstance()的使用有局限,因为它生成对象只能调用无参的构造函数,而使用 new关键字生成对象没有这个限制。

注意,Class.forName()的作用是要求JVM查找并加载指定的类,如果在类中有静态初始化器的话,JVM必然会执行该类的静态代码段。
简言之:
newInstance(): 弱类型,低效率,只能调用无参构造。
new: 强类型,相对高效,能调用任何public构造。
Class.forName(“”)返回的是类。
Class.forName(“”).newInstance()返回的是object 。


三.为什么在加载数据库驱动包的时候用的是Class.forName( ),却没有调用newInstance( )?
在Java开发特别是数据库开发中,经常会用到Class.forName( )这个方法。
Class.forName( )静态方法的目的是为了动态加载类。
通常编码过程中,在加载完成后,一般还要调用Class下的newInstance( )静态方法来实例化对象以便操作。因此,单使用Class.forName( )是动态加载类,是没有用的,其最终目的是为了实例化对象。

而在JDBC规范中明确要求这个Driver类必须向DriverManager注册自己,即任何一个JDBC Driver的 Driver类的代码都必须类似如下:

  public class MyJDBCDriver implements Driver {

  static {

              DriverManager.registerDriver(new MyJDBCDriver());

             }

  }

 既然在静态初始化器的中已经进行了注册,所以我们在使用JDBC时只需要Class.forName(XXX.XXX);就可以了。

附带:加载jdbc驱动的方式:
1.Class.forName(“com.mysql.jdbc.Driver”);

2.DriverManager.registerDriver(new com.mysql.jdbc.Driver())

3.System.setProperty(“jdbc.drivers”,”com.mysql.jdbc.Driver”);
 

优劣比较:
第二种与第三种注册的方法看起来更加的直接与好理解。

但是,第一种与第三种方法可以脱离jdbc的驱动进行编译,第二种方法不可以的,它一定要有jdbc的驱动才可以通过编译,这样对我们的程序就有很多的不好之处,为程序换数据库会带来麻烦,并且,Driver类中就有一个静态的代码块,只要我们执行了Driver类中的静态代码块,并把驱动的实例放入到Drivers的一个数组列表中,我们再调用方法registerDrever就相当于又向drivers列表中放了一次driver驱动,意思是加载了两次驱动,虽然这并不影响我们程序,但是这样做实在是没有必要,还会影响程序的运行。

第三种虽然也可以脱离,但是方法参数设置相对来说较为复杂,它可以设置多个驱动,所以在加载单个驱动时,一般采用第一种方法。

第一种方法是通过Class把类先装载到java的虚拟机中,并没有创建Driver类的实例。好处在于能够在编译时不依赖于特定的JDBC Driver库,也就是减少了项目代码的依赖性,而且也很容易改造成从配置文件读取JDBC配置,从而可以在运行时动态更换数据库连接驱动。

猜你喜欢

转载自blog.csdn.net/qq_22339457/article/details/82527317
今日推荐