在控制台进行依赖注入(DI in Console)

Posted 小曲isme

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在控制台进行依赖注入(DI in Console)相关的知识,希望对你有一定的参考价值。

首先我们准备两个服务接口

    public interface IServiceA
    {
        void showConsole();
        int GetValue(int val);
    }

  

    public  interface IServiceB
    {
        void DoWork();
        string ShowName();
    }

  接着我们分别实现两个接口

    public class ServiceA : IServiceA
    {
        private IServiceB _serviceB { get; }
        public ServiceA(IServiceB serviceB)
        {
            _serviceB = serviceB;
        }

        public int GetValue(int val)
        {
            return val;
        }

        public void showConsole()
        {
            _serviceB.ShowName();
        }
    }

  

    class ServiceB : IServiceB
    {
        private Microsoft.Extensions.Logging.ILogger _log { get; }

        public ServiceB(ILogger<ServiceB> logger)
        {
            _log = logger;
        }
        public void DoWork()
        {
            _log.LogInformation($" I am doing work ");
        }
        public string ShowName()
        {
            _log.LogInformation($" At Time :{DateTime.Now.ToString()} 被调用");
            return "I am ServiceB ";
        }
    }

  在主函数中这么写

 static void Main(string[] args)
        {
            var serviceProvider = new ServiceCollection()
            .AddLogging()
            .AddTransient<IServiceB, ServiceB>()
            .AddTransient<IServiceA, ServiceA>()
            .BuildServiceProvider();

            serviceProvider.GetService<ILoggerFactory>().AddConsole(LogLevel.Debug);
            var Logger = serviceProvider
                                        .GetService<ILoggerFactory>()
                                        .CreateLogger<Program>();
            Logger.LogDebug("Starting Program");
            var serviceB = serviceProvider.GetService<IServiceB>();
            serviceB.DoWork();
            var serviceA = serviceProvider.GetService<IServiceA>();
            var k = serviceA.GetValue(12345);
            Console.WriteLine(k);
            serviceA.showConsole();
            Logger.LogInformation("All Done ");
            Console.ReadLine();
}

  提示需要引入的Nuget包

<ItemGroup>
    <PackageReference Include="Microsoft.Extensions.DependencyInjection" Version="1.1.1" />
    <PackageReference Include="Microsoft.Extensions.Logging" Version="1.1.2" />
    <PackageReference Include="Microsoft.Extensions.Logging.Abstractions" Version="1.1.2" />
    <PackageReference Include="Microsoft.Extensions.Logging.Console" Version="1.1.2" />
  </ItemGroup>  

  运行结果:

 

以上是关于在控制台进行依赖注入(DI in Console)的主要内容,如果未能解决你的问题,请参考以下文章

控制反转(IOC)/依赖注入(DI)理解

PHP 依赖注入(DI) 和 控制反转(IoC)

spring IOC(控制反转)及DI(依赖注入)

spring in action学习笔记一:DI(Dependency Injection)依赖注入之CI(Constructor Injection)构造器注入

ASP.NET Core Web 应用程序系列- 使用ASP.NET Core内置的IoC容器DI进行批量依赖注入

如何理解 PHP的依赖注入(DI) 和 控制反转(IoC)