- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我有一个简单的问题。
假设我有一个 .Net 解决方案,有不同的项目,如一些类库(bll、dal 等)和一个可以是 Web 应用程序或 wpf 应用程序的主项目,这没关系。
现在假设我想使用 IoC 容器(如 Windsor、Ninject、Unity 等)来解析验证器、存储库、通用接口(interface)实现等内容。
我把它们放在一起。编译并运行良好。然后,有一天,我添加了一个新服务,并在我的代码中尝试通过 IoC 容器解决它。问题是,我忘记在 IoC 配置中注册它。
一切都编译完毕,应用程序被部署并运行。一切正常,除了页面代码向容器请求该新服务时,容器回答“嘿,我对这项服务一无所知”。
您会记录您的错误,以及用户友好的错误页面。您将去检查错误,查看问题并修复它。很标准。
现在假设我们想要改进流程,并且以某种方式能够在编译时知道我们期望 IoC 容器处理的每个服务是否在代码中正确注册。
如何做到这一点?一件事,单元测试被排除在可能的答案之外,我正在寻找另一种方法,如果它确实存在的话。
想法?
编辑 - 经过一些回答和评论,似乎单元测试确实是实现此功能的唯一方法。
我想知道的是,如果单元测试 - 由于任何原因 - 不可能,因此无法在编译时测试 IoC,这是否会阻止您使用 IoC 容器并选择直接实例化所有在你的代码上?我的意思是,您是否认为使用 IoC 和后期绑定(bind)太不安全和太冒险了,并且认为它的优势被这个“缺陷”所超越?
最佳答案
编译器不可能验证整个程序的工作。您的程序编译的事实并不意味着它可以正常工作(即使不使用 IoC)。为此,您将需要自动化测试和手动测试。这并不意味着您不应该尝试让编译器尽可能多地做,但出于这个原因远离 IoC 是不好的,因为 IoC 旨在保持您的应用程序灵活、可测试和可维护。如果没有 IoC,您将无法正确测试您的代码,并且如果没有任何自动化测试,几乎不可能编写任何规模合理的可维护软件。
然而,拥有 IoC 提供的灵 active 确实意味着某些特定代码段所具有的依赖项无法再由编译器验证。所以你需要用另一种方式来做到这一点。
一些 DI 框架允许您验证容器的正确性。 Simple Injector例如,包含一个 Verify()
方法,该方法将简单地遍历所有注册并为每个注册解析一个实例。通过在应用程序启动期间调用此方法(或使用类似方法),您将在(开发人员)测试期间发现 DI 配置是否有问题,它会阻止应用程序启动。你甚至可以在单元测试中做到这一点。
重要的是,测试 DI 配置不需要太多维护。如果您必须为注册的每种类型添加一个单元测试来验证容器,那么您将失败,这仅仅是因为缺少注册(因此缺少单元测试)将是首先失败的原因。
这为您提供了“几乎”编译时支持。但是,您需要注意应用程序的设计以及将事物连接在一起的方式。以下是一些提示:
NullReferenceException
s。显式属性注入(inject),即强制容器注入(inject)属性很好,但是,尽可能使用构造函数注入(inject)。Controller
实例。这样容器可以检查从根对象开始的完整依赖图。您应该以自动方式注册所有根对象,例如通过使用反射来查找所有根类型。 MVC3 Integration NuGet Package例如,Simple Injector 包含一个 RegisterMvcControllers
扩展方法,它将为您执行此操作。其他容器的集成包也包含类似的功能。Page
类,您可能会从其构造函数中调用容器(因为不幸的是 Page
类必须具有默认构造函数)。这里的关键是使用反射一次找到它们。通过使用反射查找所有 Page 类并对其进行实例化,您将发现(在应用启动或测试期间)您的 DI 配置是否存在问题。关于.net - IoC 容器,在编译时检查错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9896344/
我开始认真考虑使用 IoC 容器会引发创建过度设计的解决方案(至少它会促使我尝试使用各种不必要的功能:)。 是时候将我的“IoC”反模式列表与社区列表同步了。 我短暂的经验告诉我们,在启动时每个应用程
我一直在阅读有关控制反转框架的内容,而我只是在玩弄这个问题:“我到底为什么需要一个框架来做到这一点?” 不要误解我的问题...该模式是我们程序员经常使用的,但是...一个功能齐全的框架可以做到这一点?
想要改进这篇文章?提供这个问题的详细答案,包括引文和解释为什么你的答案是正确的。没有足够细节的答案可能会被编辑或删除。 我正在尝试确定是否需要付出额外的努力来封装我的 IoC 容器。经验告诉我,我应该
有人建议我,在使用 IOC 容器时,我应该改变这个: class Foobar: IFoobar, IDisposable {}; 进入这个: interface IFoobar: IDisposab
《畜牧代码》播客第 68 期有人,http://herdingcode.com/herding-code-68-new-year-shenanigans/ ,表示 IOC 容器不适合使用 Python
我们正在使用 NInject 框架在我们的应用程序中实现 IoC/DI。我们有具有内部方法的内部类。要实现 IoC/DI,我们必须提取接口(interface)。但是如果我们在一个内部类中只有内部方法
Spring IOC 相关接口分析 1.BeanFactory Spring 中 Bean 的创建是典型的工厂模式,这一系列的 Bean 工厂,即 IOC 容器,为开发者管理对象之间的依赖关系提供了很
MEF is not an IoC container .不过好像是差不多 一个 IoC 容器。似乎我可以很容易地让 MEF 表现得像一个 IoC 容器(见下面的例子),而且让 MEF 成为一个完整的
只是想继续了解 IOC 的原则。 Q1:静态方法 - 具有静态辅助方法的实用程序类是否应该与 IOC 连接? 例如,如果我有一个带有许多静态方法的 HttpUtils 类,我是否应该尝试通过 IOC
众所周知,在asp.net Startup 类中有一个方法ConfigureServices,我们可以添加自定义服务。服务通过依赖注入(inject)提供。 ASP.NET Core includes
所以..我一直在深入研究 IoC 容器和服务定位器。 我认为 IoC 容器是 IoC 容器,而不是服务定位器,因为 您使用它的方式。您将服务定位器传递给需要依赖项的类,然后通过容器检索依赖项。另一方面
阅读许多有关这三个成语之间差异的帖子。但是比较困惑,然后我遇到了这篇文章: http://martinfowler.com/articles/injection.html 只是想看看我是否做对了。如果
我正在寻找用于 asp.net webapi 的 ioc 容器。我们正在寻找的几个关键功能如下 自定义生命周期 对网络请求生命周期的内置支持 在管理依赖项注册方面与 Web API 的良好集成。 最佳
我很难跟随 FP。当人们说“更惯用的风格”时,我必须明白:99% 的 Java 库不适用于 Kotlin 和 Scala 的 FP 惯用风格,对吧?好吧,我需要 Spring Boot 来快速启动 V
目录 1、Spring 1.1、简介 1.2、优点 1.3、组成 1.4、扩展 2、IO
重要提示:请注意,我并不是说单例具有私有(private)构造函数和静态实例变量(或有人建议使用静态类),而是单例在应用程序生命周期内从控制容器的反转返回相同的实例。 许多容器默认使用较短的生命周期。
Closed. This question needs to be more focused。它当前不接受答案。 想要改善这个问题吗?更新问题,使它仅关注editing this post的一个问题。
松耦合当然很棒,但我经常想知道使用 IoC 容器(例如 CaSTLe Windsor)动态连接的开销对紧耦合系统有什么影响? 我知道详细的答案将取决于 IoC 的用途,但我真的只是想了解 IoC 工作
我正在努力让 IOC 在远程处理场景中工作。我将我的应用程序服务器设置为发布通过 XML 配置的服务(SingleCall)。 众所周知,这就像这样: RemotingConfiguration.Co
我使用 IoC (DI) 方法并且通常有参数,这些参数由最低层(数据库层等)从配置设置(即连接字符串、静态值等)中读取。最好的方法是什么? 直接在这个最底层读取,即: string sendGridA
我是一名优秀的程序员,十分优秀!