命名空间/解决方案结构

我很抱歉提出如此笼统的问题,但这对我来说可能具有挑战性。我的团队即将开始一个大型项目,希望将多年来发展起来的所有随机一次性代码库拖到一起。鉴于该项目将涵盖整个公司(“客户”、“员工”)、小任务、控制小任务的大任务和公用事业服务的标准化逻辑实体,我正在努力找出构建命名空间和代码结构。

虽然我想我没有给你足够的细节来继续,你是否有任何关于如何合理地拆分域的资源或建议?如果有帮助,大部分功能将通过网络服务显示,我们是一家 Microsoft 商店,提供所有最新的小玩意和小工具。

  • 我正在讨论一个包含子项目的大型解决方案,以简化引用,但这会使其过于笨拙吗?
  • 我应该结束遗留应用程序的功能,还是在命名空间中完全不可知(例如,创建一个 OurCRMProduct.Customer 类与一个通用的 Customer 类)?
  • 每个服务/项目应该有自己的 BALDAL,还是应该是一个完全独立的程序集,所有内容都引用?

我没有组织如此影响深远的项目的经验,只有一次性的,所以我正在寻找我能得到的任何指导。

请先 登录 后评论

5 个回答

Will

给猫剥皮有上百万种方法。然而,最简单的总是最好的。哪种方式对您来说最简单?取决于您的要求。但我遵循一些一般的经验法则。

首先,尽可能减少项目总数。当您一天编译 20 次时,额外的一分钟就会加起来。

如果您的应用是为可扩展性而设计的,请考虑按照设计与实现的路线拆分您的程序集。将您的接口和基类放在公共程序集中。为您公司的这些类的实现创建一个程序集。

对于大型应用程序,请将 UI 逻辑和业务逻辑分开。

简化您的解决方案。如果它看起来太复杂,它可能是。合并,减少。

请先 登录 后评论
Jedi Master Spooky

我们将 .NET 中的程序集命名为 Company.Project.XXXX.YYYY,其中 XXXX 是项目,YYYYY 是子项目,例如:

  • LCP.AdmCom.Common
  • LCP.AdmCom.BusinessObjects
  • LCP.AdmCom.Common.Dal

我们从 Krzysztof Cwalina(作者), 布拉德·艾布拉姆斯 (作者)

请先 登录 后评论
Keith

包含大量项目的大型解决方案的编译速度可能会很慢,但更易于一起管理。

我经常将单元测试程序集与他们正在测试的程序集放在同一个解决方案中,因为您倾向于一起对它们进行更改。

请先 登录 后评论
Seibar

我的建议是,在开始类似的工作后,不要为命名空间而烦恼..

只需根据一些重要的松散指南开始开发,因为无论您如何开始,您的项目都是有机的,随着时间的推移,您最终重新组织名称空间和类。

不要浪费时间过多谈论您的项目。就去做吧。

请先 登录 后评论
Rob Cooper

我最近在工作中遇到了完全相同的情况。需要结构化和组织的大量临时代码。

一开始真的很难,因为太多了。我认为我能给出的最好建议是在周五下午的放松时间投入时间,在接下来的几周里,我会选择一个应用程序/代码块,检查一下在那里,想想我们可以使什么成为通用的,复制它,把它放到我认为应该放在的新库中。一旦我迁移了应用程序中的所有代码,我就会着手重构应用程序以从通用框架中工作。这有时会导致需要修复的问题,但只要您彻底解决它就不应该太大一笔交易。

一点一点,这是唯一的方法。

在结构方面,我试图模仿 MS 命名空间,因为在大多数情况下它非常合乎逻辑(例如 Company.DataCompany.Web 、< em>Company.Web.UI 等。

主要好处之一可能是删除了大量的代码重复。是的,应用程序需要进行一些重构,但代码库要精简得多,而且在很多方面都“更智能”。

我注意到的另一件事是,我经常在试图弄清楚将东西放在哪里时遇到问题(在命名空间方面),因为我不确定它属于什么。现在这真的让我担心,我认为它是一种难闻的气味。由于重组,现在一切都更好地归入空间。并且使用(现在非常少的)应用程序特定代码,它们被放入 Company.Applications.ApplicationName 这有助于我真正考虑更多的业务对象,因为我不想在这个命名空间中使用太多,所以我想出了更灵活的设计。

对不起,长篇幅.. 有点啰嗦!

请先 登录 后评论