Spring在基于某个类生成Bean的过程中,需要利用该类的构造方法来实例化得到一个对象,但是如果一个类存在多个构造方法,Spring会使用哪个呢?
Spring的判断逻辑如下:
1. 首先如果一个类只存在一个构造方法
a. 不管该构造方法是无参构造方法,还是有参构造方法,Spring都会用这个构造方法,因为只有一个无需判断。
2. 如果一个类存在多个构造方法
a. 这些构造方法中,存在一个无参的构造方法,那么Spring就会用这个无参的构造方法。
b. 这些构造方法中,不存在一个无参的构造方法,那么Spring就会报错。
Spring的设计思想是这样的:
1. 如果一个类只有一个构造方法,那么没得选择,只能用这个构造方法。
2. 如果一个类存在多个构造方法,Spring不知道如何选择,就会看是否有无参的构造方法,因为无参构造方法本身表示了一种默认的意义。
3. 不过如果某个构造方法上加了@Autowired注解,那就表示程序员告诉Spring就用这个加了注解的方法,那Spring就会用这个加了@Autowired注解构造方法了。
但是这种情况就比较复杂了:
如果Spring选择了一个有参的构造方法,Spring在调用这个有参构造方法时,需要传入参数,那这个参数是怎么来的呢?
Spring是这样做的,会根据入参的类型和入参的名字去Spring中找Bean对象(以单例Bean为例,Spring会从单例池那个Map中去找):
1. 先根据入参类型找,如果只找到一个,那就直接用来作为入参
2. 如果根据类型找到多个,则再根据入参名字来确定唯一一个
3. 最终如果没有找到,则会报错,无法创建当前Bean对象
总结:确定用哪个构造方法,确定入参的Bean对象,这个过程就叫做推断构造方法。