Autofac的简单使用
在应用程序执行期间,您需要使用您注册的组件。 您可以在生存期范围内,通过解析Resolve它们来实现。
容器本身是一个生命周期范围,从技术上来讲,你可以直接从容器解析组件。
无论如何,不建议直接从容器中解析。
当您解析Resolve组件时,根据您定义的实例范围,将创建该对象的新实例。
解析一个组件大致相当于调用“new”来实例化一个类,虽然这么形容是过于简单化了,但这是很好的类比。一些组件可能需要进一步地处理(像他们实现IDisposable) - Autofac可以在生存期范围被清除时,为您进行处理,以清理这些组件。
但是,容器存在于你的应用程序的生命周期内。 如果你直接从容器中解析了很多东西,你最终可能会有很多东西在等待清理。 这不好(这样做,你可能会看到“内存泄漏”)。
相反,从容器创建一个子生命周期作用域并从中解析。 当你完成解析组件时,子范围的清理等等一切都为你清理干净了。
using Autofac;
using System;
namespace ConsoleApp1
{
public interface IOutput
{
void Show(string content);
}
public class ConsoleOutput : IOutput
{
public void Show(string content)
{
Console.WriteLine(content);
Console.ReadKey();
}
}
public interface IDate
{
void PrintDate();
}
public class ConsoleDate : IDate
{
private IOutput output;
public ConsoleDate(IOutput output)
{
this.output = output;
}
public void PrintDate()
{
this.output.Show(DateTime.Now.ToString());
}
}
public class ConsoleDate2 : IDate
{
public IOutput output { get; set; }//必须是属性
public void PrintDate()
{
this.output.Show(DateTime.Now.ToString());
}
}
class Program
{
private static IContainer container { get; set; }
static void Main(string[] args)
{
var containerBuilder = new ContainerBuilder();
//注意注册ConsoleDate的区别之处--构造函数注入
containerBuilder.RegisterType<ConsoleDate>().As<IDate>();
containerBuilder.RegisterType<ConsoleOutput>().As<IOutput>();
//注意注册ConsoleDate2的区别之处--属性注入
containerBuilder.RegisterType<ConsoleDate2>().As<IDate>().WithProperty("output",new ConsoleOutput());
container = containerBuilder.Build();
//不建议直接在容器中直接解析
//container.Resolve<IDate>().PrintDate();
using (var scope = container.BeginLifetimeScope())
{
scope.Resolve<IDate>().PrintDate();
}
}
}
}