AutoFac

为什么使用AutoFac?

  Autofac和其他容器的不同之处是它和C#语言的结合非常紧密,在使用过程中对你的应用的侵入性几乎为零,更容易与第三方的组件集成,并且开源

       是.NET领域最为流行的IOC框架之一,传说是速度最快的一个:

 

优点:

它是C#语言联系很紧密,也就是说C#里的很多编程方式都可以为Autofac使用,例如可以用Lambda表达式注册组件
较低的学习曲线,学习它非常的简单,只要你理解了IoC和DI的概念以及在何时需要使用它们
XML配置支持
自动装配
与Asp.Net MVC 集成
微软的Orchad开源程序使用的就是Autofac,从该源码可以看出它的方便和强大
上面的这个几乎所有讲Autofac博文都会出现的。抱着学习的心态,所以我们还是记录的细一点。

  

方法一:通过RegisterType注入
         var builder = new ContainerBuilder();
            builder.RegisterType<MyUserInfo>();
            builder.RegisterType<Service>().As<IService>();
            builder.Build();

 

方法二:注册为接口

定义Interface;定义一个IBase接口来做注入,所有的业务接口全部集成这个接口。ISqlDal 作为数据库访问接口;IRepository 作为中间存储接口

public interface IBase
    {
    }
public  interface IRepository<T> where T:class
    {
        void Insert(T entity);
    }
 public interface ISqlDal<T>where T :class
    {
        void Insert(T entity);
    }

model:UserService类继承IBase。通过构造函数获初始化Repository来存放数据

public class User
    {
        public string UserName { get; set; }
        public int Id { get; set; }
    }
 public class UserService : IBase
    {
     public UserService(){} private readonly IRepository<User> _repository; public UserService(IRepository<User> repository) { _repository = repository; } public void Insert(User c) { _repository.Insert(c); } } public class SqlDal<T> : ISqlDal<T> where T:class { public void Insert(T entity) { var a = "您添加了一个:" + entity.GetType().FullName; } }

  

SqlDal是一个泛型类所以通过 ContainerBuilder的RegisterGeneric进行泛型类的注册,RegisterType可以对非泛型类注册

  var builder = new ContainerBuilder();
            builder.RegisterGeneric(typeof(SqlDal<>)).As(typeof(SqlDal<>))
                .InstancePerDependency();
            builder.RegisterGeneric(typeof(Repository<>)).As(typeof(IRepository<>))
                .InstancePerDependency();
            builder.Register(c => new UserService((IRepository<User>)
                c.Resolve(typeof(IRepository<User>))));

            using (var container = builder.Build(ContainerBuildOptions.None))
            {
                User c = new User();
                c.UserName = "四毛";
                c.Id = 10;
                var cc = container.Resolve<UserService>();
                cc.Insert(c);
            }

当注册的类型在相应得到的容器中可以Resolve你的类实例。
builder.RegisterGeneric(typeof(SqlDal<>)).As(typeof(ISqldal<>)).InstancePerDependency();

AS可以让类中通过构造函数依赖注入类型相应的接口。

也可以使用builder.RegisterType<类>().As<接口>();来注册不是泛型的类 

Build()方法生成一个对应的Container实例,这样,就可以通过Resolve解析到注册的类型实例。
如果要获得某个泛型的实例,需要将泛型T代表的类传进去。如上c.Resolve(typeof(IRepository<Persion>))返回的是Object,需要转换为响应的接口

 

方法三:程序集注入

Assembly.Load("AutofacTest")获得响应的程序集。如果所有的文件在当前代码的程序集中可以通过 GetExecutingAssembly()方法获取当前程序集

           var services = Assembly.Load("Text.Service"); 
            builder.RegisterAssemblyTypes(services);
       //以上指定Text.Service的dll注入  可以通过where(i=>typeof(x).IsAssignableFrom(xxx) && t.Name.EndsWith("Service")) 做条件限定注入 ,此处对实现XX的实体或接口的文件并且是以Service结尾的文件做注入
            var SystemDLL = //取config中的配置
            if (!string.IsNullOrWhiteSpace(SystemDLL))
            {
                var ddlArray = SystemDLL.Split(',');//以逗号分隔 依次注入
                foreach (var dllName in ddlArray)
                {
                    var dll = Assembly.Load(dllName);
                    builder.RegisterAssemblyTypes(dll);
                }
            }
            builder.RegisterAssemblyTypes(Assembly.GetExecutingAssembly());//当前程序集注入
            var container = builder.Build();
            DependencyResolver.SetResolver(new AutofacDependencyResolver(container));//统一注册

  

转载于:https://www.cnblogs.com/li-lun/p/7593286.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、付费专栏及课程。

余额充值