C#控制台程序中使用官方依赖注入

C#控制台程序中使用官方依赖注入

asp.net core 中已经自带了一个官方的依赖注入框架,现在想把它应用到控制台程序中,控制台程序是最简洁的代码结构,摒除了其他一堆嵌入的框架代码,只包含最简洁的入口函数,是学习基础类库框架的最佳选择,为什么最佳,原因很简单,没有其他项的干扰,Demo效果清晰明了,方便写测试代码,调试也顺畅。

1. 业务接口类设计编写

先要写一个测试用的接口和类,我写了一个很简单的计算求和的接口类和方法,方便待会注入演示效果。
我设计的演示接口很简单,IBaseService 基础接口负责生成一个随机的数字,这个数字在构造函数中生成,方便待会测试注入实例的生存周期,这样设计的目的是,每回实例化都要调用构造方法,而每次执行构造方法产生的随机数是不一样的,由此验证注入的生命周期,ICalculateService 接口则负责计算求和,就是将随机数重复相加n遍,屏幕打印结果。

/// <summary>
/// 基础服务接口,用来获取一个数字
/// </summary>
public interface IBaseService
{
	/// <summary>
	/// 数字属性
	/// </summary>
	int Number { get; }
	/// <summary>
	/// 获取数字方法
	/// </summary>
	/// <returns>随机数</returns>
	int GetNumber();
}

/// <summary>
/// 计算服务接口,用来求和累加运算
/// </summary>
public interface ICalculateService
{
	/// <summary>
	/// 求和方法
	/// </summary>
	/// <param name="count"></param>
	void Sum(int count);
}

/// <summary>
/// 计算服务
/// </summary>
public class CalculateService : ICalculateService
{
	private readonly IBaseService _baseService;
	public CalculateService(IBaseService baseService)
	{
		_baseService = baseService;
	}
	public void Sum(int n)
	{
		int sum = 0;
		for (int i = 0; i < n; i++)
		{
			sum+= _baseService.Number;
		}
		Console.WriteLine($"the result of ICalculateService is { sum }");
	}
}

/// <summary>
/// 基础服务
/// </summary>
public class BaseService : IBaseService
{
	public int Number { get; }
	public BaseService()
	{
		Number = GetNumber();
		Console.WriteLine($"the Number is {Number}");
	}
	public int GetNumber()
	{
		Random rand = new Random();
		return rand.Next(1, 1000);
	}
}
2. 依赖注入使用

注入操作也和在Asp.net core中雷同,先new一个ServiceCollection,然后添加注入的所需的接口或类及范围,
之所以要for循环3次,是为了验证生命周期,和方便观察调用构造函数的次数。IBaseService接口的注入实例生命周期设置为Transient,即每次调用都会实例化一次从而产生新的随机数,而ICalculateService则采用单例模式,所以它的构造方法只被调用了一次,在控制台运行时,会在屏幕上打印结果,清晰可辨。

static void Main(string[] args)
{
	var serviceProvider = new ServiceCollection()
	   .AddTransient<IBaseService, BaseService>()
	   .AddScoped<ICalculateService, CalculateService>()
	   //.AddSingleton<ICalculateService, CalculateService>()
	   //.AddTransient<ICalculateService, CalculateService>()
	   .BuildServiceProvider();

	for (int i = 0; i < 3; i++)
	{
		var calculateService = serviceProvider.GetService<ICalculateService>();
		calculateService.Sum(10);
	}

	var baseService = serviceProvider.GetService<IBaseService>();
	for (int i = 0; i < 3; i++)
	{
		int resultNum = baseService.GetNumber();
		Console.WriteLine($"the result of IBaseService is {resultNum}");
	}
	Console.ReadKey();
}
3. 执行结果分析

单例生命周期运行截图
我们可以看到ICalculateService接口的实例确实是单例,因为构造函数只被调用了一次,随机产生的数字也没变,接着我们会把ICalculateService的注入生命周期改成Transient 瞬态,看看会有什么变化。
瞬态生命周期运行截图
很显然,它执行了五次构造方法,也就是实例化了五次,所以每回产生的随机数也不一样了。

  • 10
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值