gpt4 book ai didi

clean-architecture - 整洁架构中从网关到框架的依赖

转载 作者:行者123 更新时间:2023-12-04 12:45:54 24 4
gpt4 key购买 nike

假设我想实现一个基于 Uncle Bobs Clean Architecture 的 ASP.NET 应用程序。据我了解:

  • Asp.Net本身就是框架圈
  • Asp.Net Controller 将位于网关/接口(interface)适配器层
  • 我的业务逻辑将在用例/实体层

依赖规则说只允许从外圈到内圈的依赖。

据我了解,依赖规则不仅与控制流有关,而且与一般的代码级依赖有关。

但是:为了在“网关”圈中拥有一个 Asp.Net Controller ,它必须从 Asp.Net Controller 类派生。

问题:这会不会违反依赖规则,因为这会引入从“网关”圈到“框架”圈的编译时依赖?

更新:我在最近的博文 https://plainionist.github.io/Implementing-Clean-Architecture-AspNet/ 中更详细地讨论了这个问题。

最佳答案

是的,它违反了规则。

框架供应商对此并不关心,相反,他们努力让我们的应用程序供应商锁定他们的框架。

因此我们应该根据项目需求来选择我们的技术栈,包括框架。如果是我们快速创建原型(prototype)的需求,我们需要选择一个帮助我们做RAD的框架。如果需求告诉我们,业务概念已经建立,应用会长期存在,那么我们需要选择一个框架,让我们的应用与框架和其他工具解耦,这样我们就可以很容易地更新和/或交换工具,包括框架。

例如,Symfony 允许我们将 Controller 与框架耦合或分离。当谈到 ORM 时,我们也有这个问题,Propel 迫使我们拥有扩展 Propel 实体的实体,而 Doctrine 允许我们拥有完全不知道 ORM 的实体。

关于clean-architecture - 整洁架构中从网关到框架的依赖,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48589192/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com