Autofac

AutoFac

AutoFac 在系统IOC中占有很大作用,越来越多的项目中使用到AutoFac,但是国内很难看到完整的AutoFac介绍,所以 我打算 通过翻译 AutoFac网站关于AutoFac的介绍、例子、相关扩展等来系统的介绍AutoFac,使更多的人更加了解并能够融会贯通的使用AutoFac。

使用“英文-中文”双语方式。

 

首页:http://autofac.org/

 

Autofac is an addictive Inversion of Control container for .NET 4.5, Silverlight 5, Windows Store apps, and Windows Phone 8 apps.

Autofac 是一个为.Net 4.5,Silverlight 5(银光),Windows Store apps(Widnows商店应用)和Windows Phone 8 apps(windows手机应用)的令人激动上瘾的IOC容器。

 

Register Components

Build up containers with lambdas, types, or pre-built instances of components. You can also scan assemblies for registrations.

注册组件(组成部分)

使用lambdas,类型,预建组件实例来构建容器。你依然能够通过扫描程序集来注册。

 

var builder = new ContainerBuilder();

// Register individual components//注册单独的组件

builder.RegisterInstance(new TaskRepository)

       .As<ITaskRepository>();

builder.RegisterType<TaskController>();

builder.Register(c => new LogManager(DateTime.Now))

       .As<ILogger>();

// Scan an assembly for components//为组件注册程序集

builder.RegisterAssemblyTypes(myAssembly)

       .Where(t => t.Name.EndsWith("Repository"))

       .AsImplementedInterfaces();

var container = builder.Build();

 

Express Dependencies

Let Autofac inject your constructor parameters for you. It can also handle property and method injection.

表达式依赖

让Auto注入到你的构造器参数。它也能够黑醋栗属性和方法注入。

 

public class TaskController

{

  private ITaskRepository _repository;

  private ILogger _logger;

  // Autofac will automatically find the registered

  // values and pass them in for you.

  public TaskController(

    ITaskRepository repository,

    ILogger logger)

  {

    this._repository = repository;

    this._logger = logger;

  }

}

 

Flexible Module System

Strike a balance between the deployment-time benefits of XML configuration and the power of code with Autofac modules.

灵活的模块化系统

努力实现Xml配置部署的好处与使用Autoface Modules代码的优势的平衡。

 

// Specify complex registrations in code

public class CarTransportModule : Module

{

  public bool ObeySpeedLimit { get; set; }

  protected override void Load(ContainerBuilder builder)

  {

    builder.RegisterType<Car>().As<IVehicle>();

    if (ObeySpeedLimit)

      builder.RegisterType<SaneDriver>().As<IDriver>();

    else

      builder.RegisterType<CrazyDriver>().As<IDriver>();

  }

}

 

<!-- Change deployment-time behavior with XML -->

<autofac>

  <module type="CarTransportModule">

    <properties>

      <property name="ObeySpeedLimit" value="true" />

    </properties>

  </module>

</autofac>

 

Simple Extension Points

Autofac provides activation events to let you know when components are being activated or released, allowing for a lot of customization with little code.

简单的扩展点

Autofac 提供灵活的事件方便你知道组件是在什么时候被激活和被释放的,允许使用较少的代码实现大量的定制化。

 

var builder = new ContainerBuilder();

// Once a listener has been fully constructed and is

// ready to be used, automatically start listening.

builder.RegisterType<Listener>()

       .As<IListener>()

       .OnActivated(e => e.Instance.StartListening());

// When a processor is being constructed but before

// it's ready to be used, call an initialization method.

builder.RegisterType<Processor>()

       .OnActivating(e => e.Instance.Initialize());

var container = builder.Build();

 

Want to download Autofac or learn more? Here's how.

想下载Autofac或者了解更多?从这里开始

 

Download

The easiest way to get Autofac is through NuGet. We can generate a NuGet script for you or you can go through the NuGet Gallery.

下载

最简单的获取Autofac的方式是通过NuGet.我们可以为你生成一NuGet脚本或者通过NuGet列表

 

Learn

If you're new to Autofac, the Quick Start guide is a good place to start. There's also an official documentation site, API documentation, and lots of info on the Autofac wiki. For questions, hit us up on StackOverflow.

学习

如果你是一个Autofac的初学者,快速入门指导是一个好的开始,有官方文档站点API文档,在Autofac wiki上有很多信息。有问题,在StackOverflow上点击我们。

 

Get Involved

Found an issue? Let us know! Want to help us improve Autofac? Check out the source and our contributor's guide, and drop us a line on the discussion forum!

联系我们

发现了问题?让我们知道,想帮助我们改善Autofac?查看源代码和我们的贡献者指南,在论坛中给我们发信息。

转载于:https://www.cnblogs.com/beixing/p/3912639.html

04-01
<think>好的,我需要回答用户关于Autofac在.NET框架中的依赖注入库的使用方法的问题。首先,我需要回忆Autofac的基本概念和核心功能。Autofac是一个流行的IoC容器,用于.NET应用程序中的依赖注入,帮助管理对象的创建和生命周期。 接下来,我要确保覆盖用户可能关心的主要方面,比如基本使用步骤、注册组件的方法、生命周期管理以及与ASP.NET Core的集成。同时,用户提到了引用内容,其中提到了作用域和依赖释放,我需要将这些点整合到回答中,确保引用标识正确。 首先,介绍Autofac是什么,它的作用以及为什么使用它。然后分步骤讲解安装、容器构建、组件注册和解析。这里需要给出代码示例,比如如何创建ContainerBuilder,注册服务,并解析使用。 然后是注册组件的方法,包括类型注册、实例注册和Lambda表达式注册。这部分需要具体例子,比如注册MyService,或者使用Lambda处理复杂初始化。 生命周期管理是关键部分,用户提供的引用[1]提到作用域和依赖释放,我需要详细说明Autofac的InstancePerLifetimeScope,并举例在ASP.NET Core中如何使用,确保依赖项在作用域结束时自动释放。同时,要提醒用户注意长时间存活类中的依赖解析问题,避免内存泄漏,如引用[1]中的警告。 集成ASP.NET Core的部分,需要提到Autofac的扩展库,如何替换默认容器,并在Program.cs中进行配置。给出代码示例,展示AddAutofac()的使用,以及控制器中构造函数注入的例子。 最后,生成相关问题,涵盖高级功能、生命周期比较、与原生容器的区别以及解决循环依赖的方法,这些都能帮助用户进一步学习。 检查是否所有数学公式和独立公式使用正确格式,但看起来这里没有数学内容,可能不需要。然后确保引用正确,引用[1]和引用[2]的相关内容要自然融入回答中,比如作用域释放和构造器注入。 最后通读一遍,确保结构清晰,步骤明确,代码正确,并且引用的位置合适,没有格式错误。这样用户就能系统地了解Autofac的使用方法,并解决可能的疑问。</think>### Autofac依赖注入库在.NET框架中的使用 Autofac是.NET生态中广泛使用的轻量级**控制反转(IoC)容器**,专注于依赖注入(DI),帮助开发者解耦组件并管理对象生命周期。以下是其核心使用方法: --- #### 1. **基础使用步骤** 1. **安装NuGet包** 通过NuGet安装`Autofac`和`Autofac.Extensions.DependencyInjection`(ASP.NET Core集成需此包): ```bash Install-Package Autofac Install-Package Autofac.Extensions.DependencyInjection ``` 2. **创建容器并注册组件** 使用`ContainerBuilder`注册服务与实现: ```csharp var builder = new ContainerBuilder(); builder.RegisterType<MyService>().As<IMyService>(); // 注册接口与实现 builder.RegisterInstance(new Logger()).As<ILogger>(); // 注册单例实例 var container = builder.Build(); ``` 3. **解析依赖** 通过容器解析服务: ```csharp using var scope = container.BeginLifetimeScope(); var service = scope.Resolve<IMyService>(); // 解析服务实例 ``` --- #### 2. **组件注册方式** - **类型注册** ```csharp builder.RegisterType<EmailService>().As<INotificationService>(); ``` - **实例注册**(单例) ```csharp var cache = new MemoryCache(); builder.RegisterInstance(cache).As<ICache>(); ``` - **Lambda注册**(复杂初始化) ```csharp builder.Register(c => new ConfigReader(c.Resolve<IConfig>())) .As<IConfigReader>(); ``` --- #### 3. **生命周期管理** Autofac通过生命周期作用域(Lifetime Scope)控制对象释放,避免内存泄漏[^1]: - **瞬时实例**(每次解析新对象) ```csharp builder.RegisterType<TransientService>().InstancePerDependency(); ``` - **作用域实例**(同一作用域内单例) ```csharp builder.RegisterType<ScopedService>().InstancePerLifetimeScope(); ``` - **单例实例**(全局唯一) ```csharp builder.RegisterType<SingletonService>().SingleInstance(); ``` --- #### 4. **与ASP.NET Core集成** 在ASP.NET Core中替换默认DI容器为Autofac: ```csharp var builder = WebApplication.CreateBuilder(args); builder.Host.UseServiceProviderFactory(new AutofacServiceProviderFactory()) .ConfigureContainer<ContainerBuilder>(container => { container.RegisterModule<MyApplicationModule>(); // 模块化注册 }); ``` **控制器依赖注入示例**: ```csharp public class HomeController : Controller { private readonly IMyService _service; public HomeController(IMyService service) { _service = service; // 通过构造函数自动注入 } } ``` --- #### 5. **注意事项** - **作用域释放**:通过`BeginLifetimeScope()`创建的作用域结束时,其解析的所有瞬时/作用域实例会自动释放[^1]。 - **单例陷阱**:若单例服务依赖作用域服务,需使用`ILifetimeScope`参数或`InstancePerMatchingLifetimeScope`限定作用域[^2]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值