- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
大家好。我遇到了一个使用存储库和服务模型的奇怪设计模式。该应用程序由 ASP.NET MVC、WCF 和一些 Windows 服务组成。我的存储库正在使用 LINQ DataContext。随着我的应用程序的发展,我发现自己到处传递对 IWhateverService 服务的引用。例如,我有 IAccountService,它定义了 ChangePlan(Account account, Plan plan) 等方法。
现在,IAccountService 似乎是放置此方法的最佳位置,因为我们在这里为帐户提供服务。但是,ChangePlan 方法在实际更改计划之前需要知道几件事。它必须知道用户当前的使用情况、可用计划列表、用于计费的电子商务服务接口(interface)实例等。
我想让 ChangePlan 方法接受 IAccountService 接口(interface)中的所有必需服务。但这些其他服务的要求是一个实现问题,不应成为接口(interface)定义的一部分。
所以现在我发现自己为 AccountService 创建了一个巨大的构造函数,它采用了 IAccountRepository、IPlanService、IUsageService、IEcommerceService 和 IValidationDictionary 的实例。这感觉根本不对。
现在考虑这个场景。显然,IAccountService 包含一个通过 ID 检索用户帐户的简单方法:Account Get(int id) 有好几次我只需要调用此方法即可。因此,我开始创建我的 AccountService,它需要所有这些其他服务的实例(尤其是 IValidationDictionary,我不需要为此进行验证)。再一次,这感觉不对。我可以传递 null,但这只是因为我知道实现不会仅将它们用于此方法。
此外,为了避免在需要的任何地方实例化服务,我创建了一个名为 ServiceFactory 的静态类,它具有静态方法、CreateAccountService、CreatePlanService 等……我在应用程序周围调用这些方法。看起来不错,但我无法摆脱这种不合适的感觉。
我的断开连接在哪里?有人有什么建议吗?
谢谢。
安德鲁
最佳答案
您所描述的设计似乎与SOLID 非常一致。原则。许多较小的组件通常也被认为是好的设计。
SOLID 原则通常会接受您在实现 中描述的非规范化,并且宁愿专注于让此类组件的每个外部用例都有自己的接口(interface)。
我认为您遇到的主要问题是您花了太多时间考虑如何构造这些对象。你可能应该寻找一个依赖注入(inject)框架来处理这个问题,比如 Castle Windsor .然后,您只需构建完整状态的对象,而不必担心所有依赖项未用于每次调用。
关于c# - 我的代码充满了服务接口(interface)!,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/764817/
我有一个 Storm 拓扑,其中一个 bolt 应该与ElasticSearch交互。 public static Client client; public static Settings sett
我目前正在开发 LIMS。我需要检索与需要使用某种准备方法准备的实验室 sample 相关的信息。 (我对此进行了相当多的简化,因此对任何错误表示歉意。)我需要在查询结果中生成的列是: Sample
我必须以下文件夹结构: main - server -- server-module-1 --- a --- b --- c -- server-module-2 --- d --- e --- f
Tomcat 和我的自定义 JAAS LoginModule 运行良好,但每次我输入错误的凭据时,整个 LoginException 都会写入日志。根据定义,LoginModule 必须在身份验证失败
我一直在关注有关 iOS 开发的教程 - 特别是向下钻取 UITableViews。我建立了自己的自定义 plist,但我似乎无法让 DetailViewController 填充我的 plist 信
我对 QT 比较陌生。在我的代码中,我创建了一个 QTableWidget,遍历行并将单元格设置为 QLineEdits 和 QCheckBoxes。我想这样做,以便更改任何 QLineEdits 中
我刚开始使用 Chrome 的分析器。所以这可能是对我得到的结果的误解。 如果我打开 Chrome 分析器并拍摄以下网页的堆快照,我会注意到 obj3 的保留大小是 obj1 和 obj2 的保留大小
我正在尝试使用 Python 2.7 中的 BeautifulSoup 4 解析 youtube 评论。当我尝试播放任何 YouTube 视频时,我会收到充满 BOM 的文本,而不仅仅是在文件开头:
我有此消息的完整系统日志: mysqld[963]: 2016-10-23 20:54:14 140708269390592 [警告] 拒绝用户 ''@'localhost' 访问(使用密码:NO)
我有一个数组,里面装满了NSDictionaries。我想找到其中一本字典的 index,但我对这本字典的了解只是键 @"name"的 value。我该怎么做 ? 最佳答案 在 theArray 中查
我想在之前的div内容满了文字的时候显示div,然后继续用剩下的文字填充这个新的div。 我不知道怎么办。事实上,在下面的代码中我写道,div 是在单击按钮时显示的。我也无法设置上面解释的“填充操作”
这是发生了什么: 内部数据库内容:一个类有一个字符串属性,用于存储电话号码。这个数字是使用代码设置的 CFBridgingRelease(ABMultiValueCopyValueAtIndex(AB
我的 logcat 中收到了数千条以下警告消息,它挤掉了我实际要查找的消息: W/ActivityManager﹕ Wtf, activity ActivityRecord{4338cd90 u0 u
我尝试使用 mongoimport 在 mongodb 中导入单个 csv 文件,使用 mongoimport -d mydb -c things --type csv --file location
我的 Rails 开发日志中有大量这样的行: Started GET "/assets/services.css?body=1" for 127.0.0.1 at 2012-11-26 02:27:4
我在 Xcode 8/iOS 10/Swift 3 中遇到 Firebase 问题。试图让 Firebase Analytics 全部设置好。但是在 iOS10 中,控制台会记录来自 Firebase
我的 logcat 中充满了以下消息 - E/UsDebuggingManager( 476): java.io.IOException: Connection refused E/UsDebugg
总结 我有各种单节点 Kubernetes 集群,这些集群在累积约 300 个已完成的作业后变得不稳定。 例如,在一个集群中,有 303 个已完成的作业: root@xxxx:/home/xxxx#
我是一名优秀的程序员,十分优秀!