Constructor injection vs Field injection

好久不见. 提交于 2019-12-19 15:14:10

问题


When injecting any services, I have two choices :

(Field injection)

 @Inject 
    private MyService myService;

or ( Constructor injection )

private MyService myService; 

@Inject
public ClassWhereIWantToInject(MyService mySerivce){
    this.myService = myService;
}

Why Constructor injection is better than Filed injection ?


回答1:


Do something like (I assume you are using spring-boot or something comparable for your CDI)

public class ClassWhereIWantToInject{

    private MyService myService; 

    @Inject
    public ClassWhereIWantToInject(MyService mySerivce){
        this.myService = myService;
    }
}

At this related question there are some valid arguments why to use injection via constructor instead of injection via field. It boils down to the advantage that you can use initialization via constructor also in non-CDI environment i.e. Unit Test, without the need to add more complex logic.




回答2:


I found only two disadvantages in the field injection.

  • Hard to inject mocks when the object is under test. (Can be resolved with @InjectMocks from Mockito)

  • Circe dependencies. If bean A depends on bean B and bean B needs bean A. If you have the constructor injection it easy to find it.




回答3:


Field injection will be performed correctly if the class that contains this injected will be inject by the framework (spring/ejb/cdi), otherwise (the class will be instantiated by the caller using the new operator) it's really a NullPointerException waiting to happen. In this case, it is better to use constructor injection.

We can perform a reliable field injection, when the injection will be made in a class injected by the framework.




回答4:


Reading this excellent post (https://blog.marcnuri.com/field-injection-is-not-recommended/) we can find better explanations about why Field Injection is not a good choice.

It not allow us to make the Field immutable, using the final keyword.

It also is a step further away from SRP (Single Responsibility Principle), once the Class that has this field starts to have some responsibility on initialization timing of third-party classes.



来源:https://stackoverflow.com/questions/40737720/constructor-injection-vs-field-injection

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!