IOC三种依赖注入的方式,以及区别

文章介绍了构造方法注入、setter方法注入和接口注入这三种依赖注入方式。构造方法注入在对象创建时即完成初始化,但参数过多时构造函数会变得复杂。setter方法注入更灵活,允许后期注入,但对象可能无法立即使用。接口注入因需要额外实现接口而不被广泛推荐。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

构造方法注入(constructor injection)

构造方法中声明依赖对象的参数列表,让IoC容器知道它需要哪些依赖对象。

此方法比较直观,对象构造完成后,即进入就绪状态,可以马上使用。

public FXNewsProvider(IFXNewsListener newsListner,IFXNewsPersister newsPersister)
{
    this.newsListener = newsListner;
    this.newPersistener = newsPersister; 
}

setter 方法注入(setter injection)

只需要为依赖对象所对应的属性添加setter方法,就可以通过setter方法将相应的依赖对象设置到被注入对象中。

比构造方法注入宽松一些,可以在对象构造完成后再注入。

public class FXNewsProvider
{
    private IFXNewsListener newsListener;
    private IFXNewsPersister newPersistener;
    public IFXNewsListener getNewsListener() {
        return newsListener;
    }
    public void setNewsListener(IFXNewsListener newsListener) {
        this.newsListener = newsListener;
    }
    public IFXNewsPersister getNewPersistener() {
        return newPersistener;
    }
    public void setNewPersistener(IFXNewsPersister newPersistener) {
        this.newPersistener = newPersistener;
    }
}

接口注入(interface injection)

被注入对象如果想要IoC Service Provider为其注入依赖对象,就必须实现某个接口。这个接口提供一个方法,用来为其注入依赖对象。IoC Service Provider最终通过这些接口来了解应该为被注入对象注入什么依赖对象。

接口注入比较死板和繁琐,是现在不甚提倡的一种方式,“退役”选手。

三种方式比较

注入方法优缺点
构造方法注入构造方法注入的优点是当对象构造完成之后,就能够处于就绪状态,能够提供使用,而缺点在于如果对象太多,或者某个对象的参数多而复杂的话,构造方法就很繁琐,并且维护也是有较大的困难
setter方法注入主要体现在性能方面,因为方法可以自定义命名,描述也就更加人性化了,可以有默认值设置。不足的地方可能就是不能立即使用该对象
接口注入入侵性太强,如果需要注入依赖对象,被注入对象必须声明和实现另外的接口。不提倡这种方法
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值