前言:三种注入的例子都是用C#写的,沿用上篇博客订单与数据库的例子
构造函数注入:顾名思义,就是用构造函数的形式来实现注入
与上篇博客不同的是这里多了一个接口,Order中注入的是接口,而不再是具体的类。
SqlServerDal、Access类:
数据库实现接口,具有了添加订单的功能
using System;
namespace Ioc2
{
class SqlServerDal:IDataAccess
{
public void Add()
{
Console.WriteLine("在sqlserver数据库中添加一条订单");
}
}
}
namespace Ioc2
{
class Access:IDataAccess
{
public void Add()
{
Console.WriteLine("在access数据库中添加一条订单");
}
}
}
Order类:
用构造函数的方式将抽象出的数据库行为(接口)注入
namespace Ioc2
{
class Order
{
private IDataAccess _ida;
public Order(IDataAccess ida)
{
this._ida = ida;
}
public void Add()
{
_ida.Add();
}
}
}
数据库接口 IDataAccess:
接口是对类行为的抽象,数据库是用来添加数据的,能添加数据的不只有sqlserver数据库,所以我们将Add()这一行为抽象出来,只要能添加订单的数据库类都可以进行注入。
namespace Ioc2
{
interface IDataAccess
{
void Add();
}
}
客户端:
用哪个数据库就实例化哪个,并作为参数写入到Order类
namespace Ioc2
{
class Program
{
static void Main(string[] args)
{
//这里用的是sqlserver数据库
//如果要改为其他数据库,添加其他数据库的类并在此实例化即可
SqlServerDal dal = new SqlServerDal();
//Access access=new Access();
Order order = new Order(dal);
//调用Add()方法,添加订单
order.Add();
}
}
}