- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在考虑通过提供一些预定义的接口来增加现有应用程序的可扩展性,这些接口可以通过放置在特定位置并由应用程序接收的“插件”来实现。当插件更频繁地更新和部署时,应用程序的核心很少更新。
因此,基本上,具有这样的设置:
// in core assembly (core.dll)
public interface IReportProvider{
string GenerateReport();
}
// in other assembly(plugin.dll)
public class AwesomeReport : IReportProvider {
string GenerateReport(){ ... }
}
最佳答案
我在这个领域进行了相当广泛的工作,并且一直发现您需要确定范围内和范围外的界限。想要最大程度的扩展是有风险的,但是这一切都是有代价的。该费用要么是约定时,最佳实践的形式,要么是编译时的费用,或者可能是自动构建检查的费用,否则将是一个复杂的运行时。
要解决您列出的选项:
绑定重定向只是实现解决方案的部分工具。它们将使您的程序可以“滑动” DLL的一个版本来代替另一个版本,但是,它不能神奇地解决方法更改时发生的问题。 MissingMethodException吗?
这里您可能还没有的东西就是依赖关系链。
您可以看到,当应用程序将依赖项“ A”视为版本1对象时,它在内部从较新版本中创建了一些内容,并将其传递回应用程序并转换为v1.0-导致异常。
这可能很难处理-只是风险之一。
在各个版本中保持合同装配版本相同
这可以优雅地工作,但是,这只是将复杂性从构建时间推迟到了运行时。
您将需要努力确保所做的更改不会破坏各个版本之间的兼容性。更不用说随着应用程序的老化,您将在这些合同中收集许多您想弃用的声明。最终,该文件将变得庞大,笨拙,并给开发人员造成混乱-甚至还不能解决您拥有的所有实体合同!
我不太确定您的意思是什么,以及它如何覆盖您的问题空间。
您可以采用的另一种方法是为“ SDK”的每个主要版本创建一个新合同。这具有一些政治上的优势,因为它可以在一段时间内修复主要功能,这意味着我们可以将功能请求保持在合理的期望水平,并且超出此范围的任何内容(需要新一代合同)都推迟到下一个主要版本发布'。
但是,这确实需要对功能的设计进行认真的努力-事先考虑周全地编写合同,以便您可以抢占最明显的要求-但是,我真的觉得这无庸置疑……它们被称为“合同”因为某种原因。
每个新合同都将存在于版本名称空间中(Company.Product.Contracts.v1_0,Company.Product.Contracts.v1_1)。
我不会链接我的合同(每个新版本的合同都继承了最后一个)。这样做会使您回到保持版本号相同的问题,如果不完全打破束缚,就永远无法完全摆脱功能。
插件加载后,它可以询问主机支持的功能级别(合同版本)-以及是否是较旧的主机/较新的插件方案:或者,对插件进行编程以减少其运行时功能,以处理较少的主机功能,或只是拒绝加载。
您可能仍然应该执行这些检查,因为没有任何魔术可以使您的插件利用主机中根本不存在的功能!微软的MAF框架试图通过使用填充程序基础结构来实现这一目标,但是对于大多数人来说,这导致了大量的复杂性。
因此,您需要考虑的一些事情是:
满足您的可扩展性要求!您想要完成的所有事情都会使您付出持续维护的费用。
考虑一下您将如何弃用功能
别忘了您的合同将包含实体以及逻辑合同,它们与逻辑合同的注意事项略有不同,因为它们经常被传递得多。
仔细考虑是否在编译时而不是运行时更好地执行每个兼容性检查(反之亦然)
版本编号!程序集版本号非常适合运行时行为,文件版本号可帮助您将DLL跟踪回版本控制中的源代码-充分利用它们!
如果要执行自定义DLL解析,请使用app.config定义您的自定义DLL位置,而不是程序集解析事件。配置方法更容易预测,嘿,它是在易于阅读的Xml中声明的! Fusion Log Viewer还将很好地报告您的DLL在探测链中的插入位置,而Assembly-resolve事件将在代码中隐藏所有逻辑和规则。
唯一真正的缺点是,使用app.config意味着更改将在您的应用程序重新读取配置文件(通常是应用程序重新启动)后才会生效,但是如果您对插件进行AppDomain隔离,您甚至可以解决此问题。
与您的“ core.dll”问题有关...
我认为,对于您来说,这是一个相对简单的问题。您的Core Contract DLL中的所有内容都应存在于版本名称空间下(请参见上文,Company.Product.v1_0等),因此DLL也包含版本号实际上是有意义的。这将消除将DLL部署到bin文件夹时相互覆盖的问题。
不要依赖GAC-从长远来看,这将是一个痛苦。令人遗憾的是,开发人员似乎总是忘记了GAC会覆盖所有内容,这可能成为调试的噩梦-还会在权限方面影响您的部署方案。
如果确实需要使DLL名称保持相同-可以在应用程序中创建一个“本地gac”,这将使您能够以不相互覆盖但彼此仍然可以解析的方式存储DLL。运行时。在app.config(see my answer here)中检出“绑定重定向”。可以将其与应用程序bin文件夹下的“伪GAC文件夹结构”结合使用。然后,您的应用将能够找到所需的任何版本的DLL,而无需任何自定义程序集解析代码逻辑。
我将在您的应用程序中部署core.dll的所有以前支持的版本。
如果您的应用程序的版本为9,并且您决定也支持插件的版本7和8,则只需包含Core.7.dll,Core.8.dll和Core.9.dll。您的插件加载逻辑应检测对较早版本的Core的依赖性,并警告用户该插件不兼容。
这个话题有很多,如果我想到与您的原因有关的任何其他信息,我会回头...
关于c# - 加载程序集和版本控制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12177639/
C#内部访问修饰符的定义是内部:只能在包含程序集或友元程序集内访问。所以我的问题是什么是 C# 程序集?在包含程序集或 friend 程序集之内是什么意思?它是否意味着在同一个命名空间或项目中? 最佳
任何人都可以回答以下问题。我正在使用 c# 语言。 我可以将程序集调用为 .ddl 或 .exe 文件吗? 我可以将 Assembly Manifest 称为程序集吗? 程序集、元数据和程序集 lis
我正在从 Python 运行一个 .NET COM 程序集,只有当我将程序集 dll 和依赖项复制到我的 Python 根路径 c:\Python27 时才能使它正常工作。 这是不整洁的,所以我想将
作为世界上任何一名程序员,他/她一生中至少有一次,我正在尝试创建我的“革命性”,新的且唯一的操作系统。 :D 好吧,我正在使用虚拟模拟器(Oracle VM Virtual Box),为此我创建了一个
我创建了以下程序来读取 5 个数字,然后 dumpreg查看输入的数字... INCLUDE Irvine32.inc .data count = 5 scor
如何在保护模式下执行 IN 和 OUT 等受限指令? 我发现它需要足够高的特权级别(CPL)才能执行 IO 指令。我怎样才能在内核模式下运行,拥有 IO 权限或任何其他可能对我有帮助的东西? - 我希
目录 C# 程序集、模块和类型概念及关系 概述 程序集 模块 类型 程序集、模块和类型的关系 总结 引用
构建 maven assembly ,我留下了这样的东西: ${project.basedir} / LICENS
我的应用程序由几个核心程序集和几个扩展/插件程序集组成。为了让 MEF 知道插件必须提供的所有部件,即使我永远不会使用它们的任何部件,我也必须加载这些程序集。这使得应用程序需要更多时间来启动(如果我要
我对我们的构建基础结构有一个非常具体的要求,即将另一个 JAR 依赖项的一些内容复制到我的 Web 应用程序的特定子文件夹中。我们正在使用 maven-assembly-plugin,一个自然的方法是
为什么下面的指令会设置符号标志? mov al,0FEh sub al,2 据我了解,AL寄存器可以保存2^8 - 1或255。0FEh = 254(十进制)。减去 2 叶 252。这似乎是正数。 (
我以前使用过 NUnit,但已经有一段时间了,而且从来没有在这台机器上使用过。我在 Program Files 下解压了 2.4.8 版本,并且在尝试加载测试时不断收到此错误。 Could not l
我说的是一个使用 C# 进行游戏编程的小型游戏引擎。所以,我有一个嵌入单声道运行时的 C++ 应用程序(我称之为“启动器”)。我有一个用 C# 编写的程序集,它是我的游戏引擎类库。启动器按照 Embe
我对汇编相当陌生,并尝试从标准输入读取值(从 C 调用 scanf 函数)并将其打印回标准输出(使用 printf)。 .text readstr: .asciz "%d" #strin
谢谢帮助,我的问题是关于从下面的代码中收到的 ax 值? mov al,22h mov cl,0fdh imul cl 真机结果:ff9a 我的预期:00:9a(通过二进制相乘) 第一个数字是 22h
我正在开发一个汇编程序,该程序将整个文本文件读入缓冲区,然后将其显示在控制台中。它立即显示 24 行(每行的最大长度为 80,因为我使用 80 宽 * 25 高的 dossbox )然后等待用户输入,
我正在使用一个简单的程序集片段,使用 BIOS 作为引导加载程序的一部分将字符打印到屏幕上。这是引导加载程序代码。 [org 0x7c00] [bits 16] %include "a20_check
我只是想知道这段代码是什么意思: XOR EAX,EBX XOR EBX,EAX XOR EAX,EBX 最佳答案 那是 xor swapping . 在寄存器上执行它不会遇到常见的难看的失败案例。
我在新电脑上的 XNA 项目开始出现奇怪的错误。我有两个关于解决方案的项目和一个由它们使用的库。其中一个项目,一个 XNA 游戏项目,运行完美。另一个项目是 WindowsForm 和 XNA 的混合
是的,我正在努力实现类似的目标 __asm__(jmp label;); 其中 label 应替换为内存中保存的字符串值(结构体的字段)。 有没有办法做到这一点(或类似的方法可以让我跳转到运行时确定的
我是一名优秀的程序员,十分优秀!