最为JAVA开发者,无时无刻不在与JAVA对象打交道。
我们在日常工作中常常将创建(实例化)对象的任务交给依赖框架,如Spring。
但依旧需要了解JAVA实例化对象的比较常见的一些形式,他们分别是:
最通用、常见、普遍、简单的实例化方式,默认调用无参构造,支持调用有参构造。
/**无参构造创建对象*/
User jack= new User();
/**有参构造创建对象 有参构造的入参与自定义的构造函数一致*/
User tom = new User("mebugs","man");
使用反射的Class类的newInstance()来实例化对象,newInstance()方法将调用无参构造方法去实例化一个对象。
//方法将调用类的无参构造
User classIns = User.class.newInstance();
使用反射的Constructor类的newInstance()方法,与Class类中的newInstance()方法相似。
Constructor类的newInstance()方法我们能够调用有参构造函数和私有构造函数。
//默认调用形式
User consIns = User.class.getConstructor().newInstance();
//调用有参构造
User consInsTom = User.class.getConstructor().newInstance("mebugs","man");
//调用私有无参构造
User consInsPrive = User.class.getDeclaredConstructor().newInstance();
调用对象的clone()方法时,JVM都会为我们创建一个新对象,并将前一个对象的所有内容复制到其中。
使用clone()方法创建对象不会调用任何构造函数,但对象的类需要实现Cloneable接口并定义clone()方法。
clone()方法是比较有争议的话题,确实有它的缺点,但其是创建任何对象副本的最流行和最简单的方法。
//默认调用形式
User jack = tom.clone();
使用反序列化创建对象的前提是已经进行序列化操作。
当进行序列化和反序列化对象时,JVM会为我们创建了一个独立的对象。
在反序列化过程中,JVM不使用任何构造函数来创建对象,需要在类中实现Serializable接口。
//序列化
User tom = new User("mebugs","man");
ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("com.mebugs"));
out.writeObject(tom);
out.close();
//反序列化
ObjectInputStream in = new ObjectInputStream(new FileInputStream("com.mebugs"));
User tomBack = (User) in.readObject();
in.close();
Class类的newInstance()方法和Constructor类的newInstance()方法都被称为创建对象的反射方法。
实际上,Class类的newInstance()方法内部使用Constructor类的newInstance()方法。
这就是为什么后者更受欢迎,并且也被Spring、Hibernate等不同的经典框架所使用的原因。
上文中我们提到getConstructor()和getDeclaredConstructor()来获取Constructor类。
因此getConstructor()是getDeclaredConstructor()的子集。
当前还没有观点发布,欢迎您留下足迹!
JAVA中通过继承Thread类、实现Runnable接口以及实现Callable接口配合Future接口实现创建多线程,三种方式各有优缺点,而第三种则具备更多的增强能力
Spring就像一个大家族,里面包含了很多衍生产品,其中最为出名的就是SpringMVC和SpringBoot,那么这三者之间是什么关系呢?SpringMVC和SpringBoot又专门用来做什么呢?
JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意一个方法和属性;动态获取的信息以及动态调用对象的方法的功能。
频繁的创建与销毁线程是非常浪费系统资源的行为,多线程编程中是必要考虑到线程复用,线程池就是实现线程复用的一种方式,看看JAVA的线程池如何让使用都有哪些关键参数
有些任务需要在WEB工程启动的时候进行执行,如静态文件读取、数据库连接、初始化等,需要通过配置load-on-startup或listener相关的内容实现
SpringBoot 可以通过 spring.profiles.active 属性指定生效不同配置文件来满足多环境要求,多环境更为复杂的场景,就需要理解配置文件生效优先级,考虑直接引入外部配置项和配置文件