- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个分层解决方案如下:
我希望 BLL 有一个名为 GetProductList() 的服务,该服务在我的 DAL 层中实现。我考虑过在 BLL 和 DAL 实现中定义一个接口(interface),如下所示:
选项 A:
// Interface defined in BLL
public interface IDataServices
{
List<Product> GetProductList();
}
// Interface implemented in DAL
public class DataServices : IDataServices
{
Public List<Product> GetProductList()
{
return //do some database work here and return List<Product>;
}
}
如果我想在 DAL 中实现它,那么我必须让 DAL 项目引用 BLL 项目才能看到 IDataServices 的接口(interface)定义。或者,我可以在 DAL 中复制接口(interface)定义,但我最终会得到要维护的重复代码(BLL 和 DAL 中的相同接口(interface)定义)。
选项 B:我可以这样做的另一种方法是忘记接口(interface)的想法,只在 UI 可以使用的 BLL 中进行以下具体类和方法调用:
// Concrete class defined in the BLL
public class DataServices
{
Public List<Product> GetProductList()
{
DAL aDAL = new DAL();
Return (aDAL.GetProductList());
}
}
这很简单,但是 BLL 会看到 DAL 并引用它,但这真的是一件坏事吗?只要 BLL 不使用任何数据库对象(即数据源、连接字符串等)来满足请求并且 DAL 符合匹配我在 BLL DataServices 类中定义的服务的名称,这还不够吗?我听到的关于在另一个数据库引擎中交换的所有讨论仍然可以通过确保下一个 DAL 提供 BLL 在 DataServices 类中标识的相同服务(例如 GetProductList())来完成。在此设置中,UI 仍然不知道有关 DAL 的任何信息,而 DAL 也不知道有关 BLL 的任何信息。如果我接受使用依赖注入(inject)来避免在 BLL 中实例化 DAL 的想法,这将意味着在 UI 中实例化它以传递到 BLL 中。我不想这样做,因为这会让 UI 访问 DAL 方法。
选项 C:我简单地看了一下 Unity Container,但该工具建议在入口点预先注册所有接口(interface)和具体类,这本来是 UI,而这反过来又为 BLL 和 DAL 提供了 UI 可见性,这似乎更糟.我看到了将 MEF 与 Unity 结合使用来解决入口点看到所有层的问题的引用,但我也看到如果你这样做,你就不能真正地对这样的配置进行单元测试。与选项 B 相比,工作量和复杂性似乎很大。
选项 D:我考虑过的另一个选择是在 BLL 和 DAL 之间创建一个外观层(另一个 VS 项目)。这似乎没有多大意义,除非我最终得到了很多与 BLL 无关的 DAL 方法,因此必须隐藏它们;允许 DAL Facade 仅显示 BLL 需要的内容。如果我要交换到另一个数据库中,我仍然需要根据 BLL 的需要创建外观所需的方法,正如我在选项 B 中提到的那样。
因此,基于所有这些,我正在考虑选择选项 B,但我想在这里提供一些社区意见。满足以下条件还能做什么:
最佳答案
您的选项 A(BLL 中的接口(interface),DAL 中的实现)+ 和 IoC 容器是最佳方法。
在设计复杂的软件解决方案时,您必须将其分成更小的部分。
其中一些部分对于解决方案至关重要。它们将是您开发软件的原因,而不仅仅是购买现有解决方案。你必须专注于他们。这些部分将很复杂且难以实现。你对此无能为力。它们必须尽可能得到最好的实现。
也会有简单的作品。易于实现的功能,甚至可以购买。尝试以尽可能少的努力制作这些零件。它们是必要的,但它们不是您受雇的目的。
首先关注困难的部分。那里的业务逻辑会很复杂。业务逻辑将不依赖于您选择的存储解决方案——所以不要让它依赖于您系统中的 DAL 项目。在您的业务逻辑层中为您的实体(如果您遵循 DDD,则聚合)的存储库定义接口(interface)。
您应该能够彻底测试业务逻辑。如果 BLL 依赖于 DAL,则无法执行此操作。
UI 应该与业务逻辑完全分离。 UI 只是用户可以执行的一组用例。因此,它应该向用户提供有限的信息,并且只接受来自用户的有限信息。
要将 UI 与 BLL 分开,请使用单独的 ViewModel 和 Command 类来显示和接受来自用户的信息。在每个用例中使用额外的应用层来编排 BLL。
这种方法众所周知 Hexagonal architecture , Onion architecture或 Clean architecture .域驱动设计书籍中也引用了它。
当然,您需要一个地方将所有这些依赖项放在一起。这个地方是composition root它应该尽可能靠近应用程序入口点。如果您不想引用 UI 项目中的所有层,请将组合根移动到另一个项目。
关于c# - 除了实例化 DAL 的 BLL 之外,还有什么选项允许在 n 层解决方案中进行单元测试,而无需将 DAL 暴露给 UI 或 BLL 暴露给 DAL?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33966147/
我只是想知道要安装哪个版本的 Visual Studio 2010(专业版或高级版)提示升级项目.. 项目包括:asp.net mvc、数据库和silverlight。 最佳答案 通常,由不同版本的相
几种通过 iproute2 来打通不同节点间容器网络的方式 几种通过 iproute2 来打通不同节点间容器网络的方式 host-gw ipip vxlan 背景 之前由于需
目录 前言 1、TypeHandler 简介 1.1转换步骤 1.2转换规则 2、JSON 转换 3、枚举转换 4、文章小结
目录 前言 1、常见 key-value 2、时效性强 3、计数器相关 4、高实时性 5、排行榜系列 6、文章小结 前言 在笔者 3 年的
目录 前言 四、技术选型 五、后端接口设计 5.1业务系统接口 5.2App 端接口 六、关键逻辑实现 6.1Red
目录 前言 一、需求分析 1.1发送通知 1.2撤回通知 1.3通知消息数 1.4通知消息列表 二、数据模型设计
目录 前言 一、多租户的概念 二、隔离模式 2.1独立数据库模式 2.2共享数据库独立数据架构 2.3共享数据库共享数据架构
导读: 虽然锁在一定程度上能够解决并发问题,但稍有不慎,就可能造成死锁。本文介绍死锁的产生及处理。 死锁的产生和预防 发生死锁的必要条件有4个,分别为互斥条件、不可剥夺条件、请求与保持条件和循环等待条
在浏览网页后,我找不到任何功能来执行此操作,我有可行的个人解决方案。也许它对某人有用。 **使用 Moment 插件转换日期。***moment(currentPersianDate).clone()
是否有一种解决方案可以很好地处理数字(1-10)手写?我试过tesseract,但我得到的只是垃圾。 理想情况下是 OSS,但商业也可以。 最佳答案 OpenCV 现在带有手写数字识别 OCR 示例。
在服务器应用程序上,我们有以下内容:一个称为 JobManager 的单例类。另一个类,Scheduler,不断检查是否需要向 JobManager 添加任何类型的作业。 当需要这样做时,调度程序会执
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 5年前关闭。 Improve this qu
当您尝试从 GitHub 存储库安装某些 R 包时 install_github('rWBclimate', 'ropensci') 如果您遇到以下错误: Installing github repo
问题在以下链接中进行了描述和演示: Paul Stovell WPF: Blurry Text Rendering www.gamedev.net forum Microsoft Connect: W
我正在寻找一种解决方案,使用标准格式 a × 10 b 在科学记数法下格式化 R 中的数字。一些同行评审的科学期刊都要求这样做,并且手动修改图表可能会变得乏味。 下面是 R 标准“E 表示法”的示例,
已编辑解决方案(如下...) 我有一个启动画面,它被打包到它自己的 jar 中。它有效。 我可以通过以下方式从另一个 java 应用程序内部调用 Splash.jar: Desktop.getDesk
什么是创建像 PageFlakes 或 iGoogle 这样的门户网站的好框架/包? ?我们希望创建一个为员工提供 HR 服务的员工/HR 门户,但我们也需要一种足够灵活的产品,以便我们可以使用它来为
我正在寻找一种解决方案,使用标准格式 a × 10 b 在科学记数法下格式化 R 中的数字。一些同行评审的科学期刊都要求这样做,并且手动修改图表可能会变得乏味。 下面是 R 标准“E 表示法”的示例,
如何将 solr 与 heritrix 集成? 我想使用 heritrix 归档一个站点,然后使用 solr 在本地索引和搜索该文件。 谢谢 最佳答案 使用 Solr 进行索引的问题在于它是一个纯文本
完整日历不包含工作时间功能选项(在任何一天的议程 View 中选择第一行和最后一行 - 例如公司不工作)。我做到了类似的事情: viewDisplay: function(view){
我是一名优秀的程序员,十分优秀!