详解asp.net core 依赖注入
前言
好久没有写微博了,因为前段时间由于家庭原因决定从工作了3年多的北京转移到上海去。依赖注入在学习netcore的时候也有写过类似的东西,只是实践的较少,结果来到上海新公司系统框架涉及到了这块知识点,所以在了解完自己的项目之后决定做一些相关的总结。接下来就让我们先来了解hewi依赖注入。
什么是依赖注入
依赖注入,全称是“依赖注入到容器”,容器(IOC容器)是一个设计模式,它也是个对象,你把某个类(不管有多少依赖关系)放入这个容器中,可以“解析”出这个类的实例。所以依赖注入就是把有依赖关系的类放入容器(IOC容器)中,然后解析出这个类的实例。划重点:依赖注入是为了实现控制反转的一种设计模式。【现在知道gof之外还有其他的设计模式了吧。】
为什么要用依赖注入
我们编程希望高内聚低耦合,所以解耦是很多理论的出发点,依赖注入控制反转也是为了解耦。那么冒昧问一下啊低耦合是什么?我的理解就是:我们在编程过程中,我们不需要知道组件与类库的内容只需知道他们提供的接口,调用接口就能实现功能,我们就说这种情况是低耦合。
在没有接触到依赖注入的时候,解耦的思路其实也就是gof设计模式和设计原则。我以前分享的很多文章牵涉到的封装类库都是基于面向接口的方式。举个例子:
publicinterfaceIOrder
{
//Product产品对象
decimalValueProducts(paramsProduct[]products);
}
publicclassOrder:IOrder
{
publicdecimalValueProducts(paramsProduct[]products)
{
returnproducts.Sum(p=>p.Price*p.Number);
}
}
以上是在做商城经常写的一个基类。比如我们以前商城中购物车下单就算其总价的方法调用的时候。
publicclassShoppingCart
{
//计算购物车内商品总价钱
publicdecimalCalculateStockValue()
{
Product[]products={
newProduct{Name="龙牙2016新款",Number=2,ModelNo=121,ColorID=65,SizeID=78,Price=289.40},
newProduct{Name="龙牙2017新款",ModelNo=121,ColorID=65,SizeID=78,Number=2,Price=3800},
};
IOrderorder=newOrder();
//计算商品总价钱
decimaltotalValue=order.ValueProducts(products);
returntotalValue;
}
}
以上是我常用的方式来处理自己的业务需求的。这种面向接口的方式,如果我们要计算金额的方式改变了,比如我们尺寸32的金额打7折,那么只需增加金额的类。改变接口实例化即可。代码就不敲了应该都懂吧(低耦合)。那么我们可以看出ShoppingCart是依赖于接口与实现的对不对,那么现在我们考虑一个问题,购物车虽然调用接口实例化,但是它也是要依赖于order的,那么减少它的依赖性有没有办法——就是把他们完全分开。那么这种问题的解决就用到了依赖注入了。划重点:依赖注入就是减少对接口实例化对象的依赖。那么怎么来实现依赖注入呢?
构造注入的实现
通过类的构造函数
第一次看netcore别人也是讲的这种方式,下面看一下代码。设置一个服务类接口类型的数据成员,并以构造函数为注入点,这个构造函数接受一个具体的服务类实例为参数,并将它赋给服务类接口类型的数据成员。
publicclassShoppingCart
{
IOrderorder;
//构造函数,参数为实现了IOrder接口的类的实例
publicShoppingCart(IOrder_order)
{
order=_order;
}
//计算购物车内商品总价钱
publicdecimalCalculateStockValue()
{
Product[]products={
newProduct{Name="龙牙2016新款",Number=2,ModelNo=121,ColorID=65,SizeID=78,Price=289.40},
newProduct{Name="龙牙2017新款",ModelNo=121,ColorID=65,SizeID=78,Number=2,Price=3800}};//计算商品总价钱
decimaltotalValue=order.ValueProducts(products);
returntotalValue;
}
以上代码最秒的地方就是ShoppingCart与接口IOrder的实现order完全没有关系,不需要了解他是怎么实现的。这就是依赖注入。这种叫做构造注入。
在我们讨论下一种注入的方式的时候,有个问题其实还没有解决。“依赖是如何产生的?”把依赖当作构造函数参数来写,尽管使用这可以手动提供这种依赖,但是当整个系统都依赖注入,那就意味着任何一个组件我们都需要知如道满足每一部分的需求(服务定位器),是不是很头大?那么这时我们就要要引入一个概念的“容器”-----依赖注入容器。
protectedoverridevoidRegisterBuilder(ContainerBuilderWrapperbuilder)
{
base.RegisterBuilder(builder);//注入仓储
builder.RegisterType().As();
}
以上为mvc容器的一种实现。AS后边是服务类继承的接口,其实我对它的理解就是:如果有人请求这种类型。我们就给他这个类型的对象。
属性注入
其实依赖注入spring相关的资料应该有很多,所以很多知识点也是通过java那的理论借鉴过来的。属性注入我确实看的net的书了解的。
如果需要使用到被依赖对象的某个属性,在被依赖对象被创建之后,IoC容器会自动初始化该属性
首先还是定一个接口
publicinterfaceIorder
{
{
//Product产品对象
decimalValueProducts(paramsProduct[]products);
}
}
属性注入如下:
publicclassShoppingCart
{
privateiordre_order;
publiciordreOrder
{
get{return_order;}
set{_order=value;}
}
publicdecimalValueProducts(paramsProduct[]products)
{
returnOrder.ValueProducts(products);
}
}
Setter注入
设置一个服务类接口类型的数据成员,并设置一个Set方法作为注入点,这个Set方法接受一个具体的服务类实例为参数,并将它赋给服务类接口类型的数据成员。其实这种是注入方式较为灵活使用者也较多。
//服务接口
internalinterfaceIServiceClass
{
StringServiceInfo();
}
//服务方法
internalclassServiceClassA:IServiceClass
{
publicStringServiceInfo()
{
return"我是ServceClassA";
}
}
//服务方法
internalclassServiceClassB:IServiceClass
{
publicStringServiceInfo()
{
return"我是ServceClassB";
}
}
//客户类实现set
internalclassClientClass
{
privateIServiceClass_serviceImpl;
publicvoidSet_ServiceImpl(IServiceClassserviceImpl)
{
this._serviceImpl=serviceImpl;
}
publicvoidShowInfo()
{
Console.WriteLine(_serviceImpl.ServiceInfo());
}
}
//调用
classProgram
{
staticvoidMain(string[]args)
{
IServiceClassserviceA=newServiceClassA();
IServiceClassserviceB=newServiceClassB();
ClientClassclient=newClientClass();
client.Set_ServiceImpl(serviceA);
client.ShowInfo();
client.Set_ServiceImpl(serviceB);
client.ShowInfo();
}
}
结束语
其实依赖注入可聊的有很多,netcore的出现依赖注入是必不可少的一个知识点。后面可聊的比如依赖注入与反射,依赖注入与多态,依赖注入的框架。。。。。。。
好久不写博客,准备的也不够充分。有兴趣的小伙伴就去网上找去吧。
.net书的话:
《aspnetmvc5高级编程》《DependencyInjectionin.NET》(没有中文)
java相关的书应该会多一些。有兴趣的就一起学习一下吧。
以上就是详解asp.netcore依赖注入的详细内容,更多关于asp.netcore依赖注入的资料请关注毛票票其它相关文章!