7.28.1 Spring构造注入还是设置注入
Posted ~~晴天~^.^
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了7.28.1 Spring构造注入还是设置注入相关的知识,希望对你有一定的参考价值。
1.
构造方法注入代码如下:public UserManagerImpl(UserDao userDao) {
this.userDao = userDao;
}
set注入代码如下: public void setUserDao(UserDao userDao) {
this.userDao = userDao;
}
构造方法注入与set注入的区别:构造方法注入的方式,在new UserManagerImpl对象的同时,就把userDao对象传给UserManagerImpl这个正在new的对象,它的时机比较早。
构造方法注入: 先把UserManagerImpl创建好以后,再调用set方法。
2.
使用构造方法注入的理由:
n 构造方法注入使用强依赖规定,如果不给足够的参数,对象则无法创建。
n 由于Bean的依赖都通过构造方法设置了,那么就不用写更多的set方法,有助于减少代码量。
使用set注入的理由:
n 如果Bean有很多的依赖,那么构造方法的参数列表会变的很长。
n 如果一个对象有多种构造方法,构造方法会造成代码量增加。
n 如果构造方法中有两个以上的参数类型相同,那么将很难确定参数的用途。
n ……
Spring官方更推荐使用set注入。
3.
下面对spring依赖注入的两种方式进行一些介绍和比对。Spring依赖注入的两种方式是:
3.1.设置注入;
3.2 .构造注入;
spring依赖注入之设置注入的优点:
与传统的JavaBean的写法更相似,程序员更容易理解、接受,通过setter方式设定依赖关系显得更加直观、明显;
对于复杂的依赖关系,如果采用构造注入,会导致构造器过于臃肿,难以阅读。Spring在创建Bean实例时,需要同时实例化其依赖的全部实例,因而导致死你功能下降。而使用设置注入,则避免这下问题;
尤其在某些属性可选的情况下,多参数的构造器更加笨拙。
spring依赖注入之构造注入的优点:
构造注入可以再构造器中决定依赖关系的注入顺序,优先依赖的优先注入。
对于依赖关系无须变化的Bean,构造注入更有用处;因为没有setter方法,所有的依赖关系全部在构造器内设定,因此,不用担心后续代码对依赖关系的破坏。
依赖关系只能在构造器中设定,则只有组件的创建者才能改变组件的依赖关系。对组件的调用者而言,组件内部的依赖关系完全透明,更符合高内聚的原则;
建议采用以设置注入为主,构造注入为辅的注入策略。对于依赖关系无须变化的注入,尽量采用构造注入;而其他的依赖关系的注入,则考虑采用设置注入。
楼主你说的私有变量 也叫状态,而方法叫做行为;
你也知道,一个类的私有变量在类外部是无法访问的,也就是无法直接修改私有变量;
而构造对象的时候,有些状态是必须的,或在对象生命周期中不会修改的状态,在构造对象时对其进行初始化更方便,更安全(没有其他方法可以改变,只能在构造函数中初始化,或setXXX()都是private修饰);
有些状态是可选的,或临时的,对象在其生命周期中是可发生改变的,所以需要更改器方法(setXXX())来对其值进行修改;
比如说,设计一个Person类时,如果要求身份证号,姓名和性别 是必需初始化的,且不会改变的;而地址,E-Mail,电话号等是可选的;你说怎么设计最好呢?
以上是关于7.28.1 Spring构造注入还是设置注入的主要内容,如果未能解决你的问题,请参考以下文章