- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我们正在为公司内部使用的测试自动化构建 .NET 软件平台。
该应用程序由一个 GUI (WinForms) 组件和动态加载到其中以供执行的各种“操作”组成。
大约有 100 个行动项目已经在进行中,而且这个数字还在增加。其中一些项目与其他项目相互依赖等等。
加载的所有操作都必须引用我们的“SDK”dll 以进行各种事件(主应用程序的结果、日志记录等)。
通过这种相对简单的设计,我们面临着一些我们希望以最佳方式解决的管理决策:
对于这样的事情,最好的解决方案是什么?为什么?
在管理相互关联的多个项目的场景中,常见做法是什么?这样做有什么技巧吗?
最佳答案
这是一个没有明确答案的问题,但是...
您可以选择两条路径。强耦合系统或松耦合系统。
对于强耦合系统,我可以为二进制文件建议两个目录:第 3 方目录和包含您公司构建的其他开发人员可以引用的 DLL 的目录。第 3 方 DLL(贵公司外部)应位于源代码控制中,以便所有开发人员从同一位置引用相同版本的第 3 方 DLL,这避免了开发人员机器不一致以及在每台机器上安装第 3 方软件的问题。内部 DLL 不应在源代码控制中引用,并且应通过自动构建批处理文件或类似文件在每个开发人员机器上构建。在构建后期步骤中,您可以将它们全部复制到同一目录,只要开发人员获得最新的源代码控制和构建,公司内的每个人都可以拥有相同的 DLL。
例如,获取最新版本、构建(使用批处理文件构建所有需要的项目),然后作为构建后步骤将输出复制到 common。现在,您的所有其他项目都可以从同一位置引用常见的公司 DLL 和第三方 DLL,并且每个人都是一致的。
问题在于引用是强耦合的,因此如果沟通不当,更改有时会出现问题。
松散耦合的系统使用 MEF(托管可扩展性框架)等框架,您的组件引用定义组件接口(interface)的“Contract DLL”。项目引用接口(interface)或契约(Contract) DLL,并不真正关心实现,然后 MEF 为您管理插件。
在这种情况下,您引用接口(interface) DLL 而不是实现的实际 DLL。
例如,假设我有一个名为 ILog 的接口(interface)和一个名为 LogMessage 的方法。
private ILog _logger;
_logger.LogMessage();
因此,在强耦合情况下:Action.DLL 直接引用 Logger.DLL。
在松散耦合的情况下,Action.DLL 引用 ILog.DLL(只是接口(interface))。 Logger.DLL 实现 ILog.DLL。但是 Action.DLL 没有直接引用 Logger.DLL。
现在我可以拥有任意数量的 DLL 来实现 ILog 接口(interface),但 Action.DLL 不直接引用它们。这非常酷,并且是 MEF 和一般松耦合的更令人兴奋的功能之一,即没有依赖性的能力。
您选择的方式,无论哪种方式都是可以接受的,我认为松散耦合的想法最适合您的场景,因为团队只需要了解契约(Contract)与实际实现。
我不会有一个庞大的契约(Contract) DLL,我会尝试将接口(interface)分解为逻辑分组。例如,日志记录似乎是一种实用程序类型的接口(interface),因此我将创建一个带有 ILog 接口(interface)的实用程序契约(Contract) DLL。它如何拆分取决于您要做什么。或者每个接口(interface)都可以是一个契约 DLL,但也许这有点极端。
关于c# - 不断增长的 .NET 项目的管理和结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6429258/
我正在使用 NetBeans 开发 Java 中的 WebService,并使用 gradle 作为依赖管理。 我找到了this article关于使用 gradle 开发 Web 项目。它使用 Gr
我正在将旧项目从 ant 迁移到 gradle(以使用其依赖项管理和构建功能),并且在生成 时遇到问题>eclipse 项目。今天的大问题是因为该项目有一些子项目被拆分成 war 和 jar 包部署到
我已经为这个错误苦苦挣扎了很长时间。如果有帮助的话,我会提供一些问题的快照。请指导我该怎么办????在我看来,它看起来一团糟。 *** glibc detected *** /home/shivam/
我在 Ubuntu 12.10 上运行 NetBeans 7.3。我正在学习 Java Web 开发类(class),因此我有一个名为 jsage8 的项目,其中包含我为该类(class)所做的工作。
我想知道 Codeplex、GitHub 等中是否有任何突出的项目是 C# 和 ASP.NET,甚至只是 C# API 与功能测试 (NUnit) 和模拟(RhinoMocks、NMock 等)。 重
我创建了一个 Maven 项目,包装类型为“jar”,名为“Y”我已经完成了“Maven 安装”,并且可以在我的本地存储库中找到它.. 然后,我创建了另一个项目,包装类型为“war”,称为“X”。在这
我一直在关注the instructions用于将 facebook SDK 集成到我的应用程序中。除了“helloFacebookSample”之外,我已经成功地编译并运行了所有给定的示例应用程序。
我想知道,为什么我们(Java 社区)需要 Apache Harmony 项目,而已经有了 OpenJDK 项目。两者不是都是在开源许可下发布的吗? 最佳答案 事实恰恰相反。 Harmony 的成立是
我正在尝试使用 Jsoup HTML Parser 从网站获取缩略图 URL我需要提取所有以 60x60.jpg(或 png)结尾的 URL(所有缩略图 URL 都以此 URL 结尾) 问题是我让它在
我无法构建 gradle 项目,即使我编辑 gradle 属性,我也会收到以下错误: Error:(22, 1) A problem occurred evaluating root project
我有这个代码: var NToDel:NSArray = [] var addInNToDelArray = "Test1 \ Test2" 如何在 NToDel:NSArray 中添加 addInN
如何在单击显示更多(按钮)后将主题列表限制为 5 个(项目)。 还有 3(项目),依此类推到列表末尾,然后它会显示显示更少(按钮)。 例如:在 Udemy 过滤器选项中,当您点击查看更多按钮时,它仅显
如何将现有的 Flutter 项目导入为 gradle 项目? “导入项目”向导要求 Gradle 主路径。 我有 gradle,安装在我的系统中。但是这里需要设置什么(哪条路径)。 这是我正在尝试的
我有一个关于 Bitbucket 的项目。只有源被提交。为了将项目检索到新机器上,我在 IntelliJ 中使用了 Version Control > Checkout from Ve
所以,我想更改我公司的一个项目,以使用一些与 IDE 无关的设置。我在使用 Tomcat 设置 Java 应用程序方面有非常少的经验(我几乎不记得它是如何工作的)。 因此,为了帮助制作独立于 IDE
我有 2 个独立的项目,一个在 Cocos2dx v3.6 中,一个在 Swift 中。我想从 Swift 项目开始游戏。我该怎么做? 我已经将整个 cocos2dx 项目复制到我的 Swift 项目
Cordova 绝对是新手。这些是我完成的步骤: checkout 现有项目 运行cordova build ios 以上生成此构建错误: (node:10242) UnhandledPromiseR
我正在使用 JQuery 隐藏/显示 li。我的要求是,当我点击任何 li 时,它应该显示但隐藏所有其他 li 项目。当我将鼠标悬停在文本上时 'show all list item but don
我想将我所有的java 项目(223 个项目)迁移到gradle 项目。我正在使用由 SpringSource STS 团队开发的 Gradle Eclipse 插件。 目前,我所有的 java 项目
我下载this Eclipse Luna ,对于 Java EE 开发人员,如描述中所见,它支持 Web 应用程序。我找不到 file -> new -> other -> web projects
我是一名优秀的程序员,十分优秀!