- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我开始从事一个新项目,我来自直接和“幼稚”的编程。
现在我担心使用 IoC 容器,特别是使用 Autofac 的依赖注入(inject)模式。
假设我有一个简单的 session 工厂:
namespace Warehouse.Data
{
public class SessionFactory
{
private static ISessionFactory _sessionFactory;
private static ISystemSetting _systemSetting;
SessionFactory(ISystemSetting systemSetting)
{
_systemSetting = systemSetting;
InitializeSessionFactory();
}
private static void InitializeSessionFactory()
{
_sessionFactory = Fluently.Configure()
.Database(DatabaseConfiguration)
.Mappings(m => m.FluentMappings.AddFromAssemblyOf<MyMap>())
.BuildSessionFactory();
}
public static ISession OpenSession()
{
return _sessionFactory.OpenSession();
}
}
}
在 Bootstrap.cs 中,我这样配置 autofac :
namespace Warehouse.Infrastructure
{
using Autofac;
public class Bootstrap
{
public IContainer Configure()
{
var builder = new ContainerBuilder();
builder.RegisterType<SystemSetting>().As<ISystemSetting>();
builder.RegisterType<UserRepository>().As<IUserRepository>();
return builder.Build();
}
}
}
我的问题是:
builder.Resolve<ISystemSetting>
吗?每次我想使用 SessionFactory 作为参数?谢谢。
最佳答案
您已经在 Bootstrap 中完成了。
builder.RegisterType<SystemSetting>().As<ISystemSetting>();
这意味着每个依赖于 ISystemSettings 的对象都会获得一个 SystemSettings 实例。所以如果你使用
var mySessionFactory = myContainer.Resolve<SessionFactory>();
在你的代码中的某个地方(你真的应该在你的组合根中这样做)容器会为你完成这项工作。如果您有很多对象,具有多个依赖项,您将开始理解为什么 IoC 容器是“神奇的”;)
嗯 .. 很多 IoC 容器都使用解析这个词。它只是意味着“给我一个对象及其依赖项”。服务和单例是面向对象设计语言中的词。它们并不特定于 IoC 容器。你可以用谷歌搜索它们。我认为没有像这样的东西的总结。您将通过阅读书籍、文章和学习教程及时获得它。
没有。实际上那是不行的。有一种称为 servicelocator 的模式,有些人认为它是一种反模式。如果您遵循这种模式,那么您的所有对象都只有一个依赖项,即容器!他们自己从中得到他们需要的东西。
public class MyClass
{
private DependencyOne dep1;
public MyClass(WhatEverContainer container)
{
dep1 = container.Resolve<DependencyOne>();
}
}
... 在那种情况下,您的容器将充当服务定位器,并且每个需要依赖项的对象都会要求服务定位器获取该依赖项。这会破坏控制反转的全部值(value),并使您的对象依赖于容器。注入(inject)对象实际需要的东西,而不是他们需要的东西,以便找到他们真正需要的东西;D
让您的对象与容器无关。并在你的组合根中使用你的容器,那是你将应用程序的对象和层粘合在一起的地方。这里有一些东西要读:http://blog.ploeh.dk/2011/07/28/CompositionRoot/
关于c# - Autofac依赖注入(inject)实现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16450172/
我有一个泛型类( GenericClass ),它依赖于泛型类型( IGenericDependency )。这种依赖也是通用的。 public class GenericClass {
虽然我通常认为 Autofac 文档(在 wiki 上)很有帮助,但关于 XML 配置和模块的部分对我来说有点不清楚。现在,我有一个示例工作(我在下面介绍),但我不确定它是否代表了 Autofac 上
我是 autofac 的新手(使用 2.1.14.854),我仍在努力理解 我有一个接口(interface),这个接口(interface)有一个或多个实现,并且应该按特定顺序触发这些实现。 例如:
使用Autofac,可以做到这一点吗?我没有实例的类型。 var instance = container.Resolve("someStringKey"); 从一些谷歌搜索来看,这似乎不可能,但我想
我有一个进行数据处理的应用程序。有 class Pipeline { IEnumerable Filters {get; set;} 我将过滤器实现注册为 builder.RegisterType
我正在尝试将域事件引入项目中。 Udi Dahan 的帖子 - http://www.udidahan.com/2009/06/14/domain-events-salvation/ 中描述了这一概念
假设这个场景: public class B {}; public class C { public C(B b){} } 要从 Autofac 容器解析 C,我必须将 B 和 C 注册到容
我正在为第 3 方应用程序构建一个插件,我的插件使用 Autofac 来连接各种组件。容器是在应用程序启动时构建的,但主机应用程序稍后会调用我的命令。 调用命令时,主机应用程序会提供一些它定义的类型实
我有一个银行/集合,它在内存中缓存对象的实例,以便每个请求不需要返回到数据存储。我希望 Autofac 提供该银行的一个实例,但在 x 秒后使其过期,以便在下一个请求时创建一个新实例。我很难理解如何设
有人可以用简单的英语解释一下我放置问号的代码行的作用吗?或者给我指点一篇阐明这一点的文章。此代码用于在 autofac 容器中注册依赖项 var builder = new Autofac.Conta
我有以下类(class): public class Errors { private readonly string _connectionString; public Errors
假设所有依赖项都已在程序开始时注册。在程序的后面部分,如何使用 AutoFac 使用无参数构造函数创建一个新对象并将注册的属性注入(inject)到该对象中? 最佳答案 您可以使用 Propertie
我使用以下代码进行注册: builder.RegisterType().Named(".VCF"); builder.RegisterType().Named(".VCARD
我有一个工厂接口(interface)(连同具体实现): // foo.dll interface IFooProvider { T GetFoo() where T : Ba
我遇到的情况是,发布者和消费者位于同一个应用程序中。我正在使用 autofac。 据我了解,我需要 2 个具有 2 个端点的总线实例,一个用于发布者,一个用于订阅者。 我正在使用 autofac,但我
我正在使用 Autofac 构造函数注入(inject)。我需要弄清楚如何将单个对象实例注入(inject)多个构造函数参数,而不需要在容器设置阶段显式解析每个参数。 我有一个复杂的场景,可以通过这种
我们在我们的 PCL (Profile259) 中使用 Autofac 3.5.2,Nuget 告诉我们版本 4.1 可用,但当我们尝试更新它时,Nuget 失败并显示以下消息: “您正在尝试将此软件
我的情况是发布者和消费者坐在同一个应用程序中。我正在使用 autofac。 据我了解,我需要 2 个具有 2 个端点的总线实例,一个用于发布者,一个用于订阅者。 我正在使用 autofac,但我不知道
在 Autofac 2.1 的 beta 版本中,支持自动解析 Lazy如 Nicholas Blumhardt 的 Lazing Around with Autofac 中所述博客文章。 The c
我有这个类要在单元测试中实例化: public class Customer { internal Customer(Guid id) { // initialize prop
我是一名优秀的程序员,十分优秀!