- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在生产代码中调用 container.Verify()
是最佳实践吗?我正在考虑搬到:
#IF Debug
container.Verify();
#ENDIF
我没有任何真正的理由进行更改,只是想知道一般共识/最佳实践是什么。
最佳答案
调用 Verify
是否有用还有待商榷。回到 2011 年,Mark Seemann没想到such a method is close to worthless .我的观点是调用 Verify
具有真正的值(value),但我理解 Mark 的观点并同意调用 Verify
本身通常是不够的。这就是为什么在 Verifying the container’s configuration 上有明确的指导在 Simple Injector wiki 中关于保持 DI 配置可验证的内容。
但是,使用 Simple Injector 时,Verify
所做的不仅仅是测试它是否可以创建您的对象图。调用 Verify
将启动 Simple Injector 的 Diagnostic Services它搜索非常常见但有时很难发现的配置错误(在 Mark 撰写该文章期间该功能不可用)。
一般来说,我的建议是在您的生产代码中调用 container.Verify
,只要可行。始终在启动时调用它,无论是在调试和发布构建中,还是在您的暂存环境和生产环境中。
随着应用程序变得越来越大,在启动期间调用container.Verify
会变得更耗时。某些类型的应用程序对此比其他应用程序更敏感。对于服务器应用程序,启动时间较长通常是可以的,而桌面和手机应用程序必须启动得更快。
一旦您发现调用 Verify
花费的时间太长 - 但仅此而已 - 您应该删除对 Verify
的调用,但至少仍然有调用 container.Verify
的单元/集成测试。我认为在编译器指令中包装 Verify
没有问题(正如您在问题中所做的那样),但再次注意 IMO,您应该推迟在启动时删除对 Verify
的调用尽可能长的路径。
关于c# - 生产代码中的简单注入(inject)器验证(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24153454/
我正在尝试测试依赖于其他服务 authService 的服务 documentViewer angular .module('someModule') .service('docu
如果我的网站上线(不要认为它会,目前它只是一个学习练习)。 我一直在使用 mysql_real_escape_string();来自 POST、SERVER 和 GET 的数据。另外,我一直在使用 i
我有以下代码,它容易受到 SQL 注入(inject)的攻击(我认为?): $IDquery = mysqli_query($connection, "SELECT `ID` FROM users W
我一直在自学如何创建扩展,以期将它们用于 CSS 注入(inject)(以及最终以 CSS 为载体的 SVG 注入(inject),但那是以后的问题)。 这是我当前的代码: list .json {
这个简单的代码应该通过 Java Spring 实现一个简单的工厂。然而结果是空指针,因为 Human 对象没有被注入(inject)对象(所以它保持空)。 我做错了什么? 谢谢 配置 @Config
我正在编写一个 ASP.NET MVC4 应用程序,它最终会动态构建一个 SQL SELECT 语句,以便稍后存储和执行。动态 SQL 的结构由用户配置以用户友好的方式确定,具有标准复选框、下拉列表和
首先让我说我是我为确保 SQL 注入(inject)攻击失败而采取的措施的知己。所有 SQL 查询值都是通过事件记录准备语句完成的,所有运算符(如果不是硬编码)都是通过数字白名单系统完成的。这意味着如
这是 SQL 映射声称可注入(inject)的负载: user=-5305' UNION ALL SELECT NULL,CONCAT(0x716b6b7071,0x4f5577454f76734
我正在使用 Kotlin 和 Android 架构组件(ViewModel、LiveData)构建一个新的 Android 应用程序的架构,并且我还使用 Koin 作为我的依赖注入(inject)提供
假设 RequestScope 处于 Activity 状态(使用 cdi-unit 的 @InRequestScope) 给定 package at.joma.stackoverflow.cdi;
我有一个搜索表单,可以在不同的提供商中搜索。 我从拥有一个基本 Controller 开始 public SearchController : Controller { protected r
SQLite 注入 如果您的站点允许用户通过网页输入,并将输入内容插入到 SQLite 数据库中,这个时候您就面临着一个被称为 SQL 注入的安全问题。本章节将向您讲解如何防止这种情况的发生,确保脚
我可以从什么 dll 中获得 Intercept 的扩展?我从 http://github.com/danielmarbach/ninject.extensions.interception 添加了
使用 NInject 解析具有多个构造函数的类似乎不起作用。 public class Class1 : IClass { public Class1(int param) {...} public
我有一个 MetaManager 类: @Injectable() export class MetaManager{ constructor(private handlers:Handler
我是 Angular 的新手,我不太清楚依赖注入(inject)是如何工作的。我的问题是我有依赖于服务 B 的服务 A,但是当我将服务 A 注入(inject)我的测试服务 B 时,服务 B 变得未定
我正在为我的项目使用 android 应用程序启动、刀柄和空间。我在尝试排队工作时遇到错误: com.test E/WM-WorkerFactory: Could not instantiate co
我不确定这是什么糖语法,但让我向您展示问题所在。 def factors num (1..num).select {|n| num % n == 0} end def mutual_factors
简单的问题,我已经看过这个了:Managing imports in Scalaz7 ,但我不知道如何最小化注入(inject) right和 left方法到我的对象中以构造 \/ 的实例. 我确实尝
在我的 Aurelia SPA 中,我有一些我想在不同模块中使用的功能。它依赖于调用时给出的参数和单例的参数。有没有办法创建一个导出函数,我可以将我的 Auth 单例注入(inject)其中,而不必在
我是一名优秀的程序员,十分优秀!