依赖注入系统中的事件朝哪个方向发展?

2024-05-11

上或下?

我是一个非常注重视觉的人。我将我的应用程序视为一个层次结构,顶部是根,底部是叶子。

我还了解到,在 DI 系统中,容器不知道其所包含对象的职责/功能。相反,所包含的对象知道它们的上下文,因为上下文(依赖项)被注入。

UP: (非 DI 方式?)
我的事件是否应该从bottom我的等级制度和泡沫向上到他们的父母?例如。我的 GUI 中的一个按钮会调度一个CLICKED事件,由侦听容器捕获,并通过执行适当的操作进行响应。

DOWN: (DI方式?)
我的事件是否应该从top孩子听从父母的安排?例如。 --...好吧,我很难想出这个。我正在思考为所包含的对象调度事件的中介者的思路。

“向上”对我来说似乎很自然,但由于 DI 有一个容器不知道其所包含的对象的行为,所以我不想响应它们的事件。

编辑(澄清):

我意识到几乎可以让系统的任何部分监听事件,但我想了解 DI 参与者之间的基本关系,以便我可以构建它们properly。我假设人们通常不会只是分散有关他们的程序的事件而不考虑结构关系、依赖关系等。

我的问题源于 DI 系统中的责任放置——注入对象的责任是调用注入器,注入器的责任是为其依赖对象提供服务(这颠倒了非 DI 范式——因此有“反转”之类的同义词)控制”和“依赖倒置”)。这似乎是 DI 的一个非常重要的基本组成部分——责任的转移。我认为调用对象的函数或侦听其事件都是以下示例取决于在另一个物体上。当一个对象基于另一个对象定义自己的行为时,我将其称为依赖关系,因为一个对象知道另一个对象,也知道另一个对象做什么。它在另一个对象的上下文中定义了自己。据我了解,DI 的设置使得注入对象依赖于注入器,因此注入对象有责任了解有关注入器的所有信息。并且注入者不应该有责任了解注入的对象。因此,对于注入器来说,侦听包含的注入对象上的事件在我看来就像是职责的错位,因为这意味着它了解其内容。

请告诉我这是否错误以及如何错误。


依赖注入和观察者模式中的角色分配是正交的关注点。一个对象可以扮演观察者或被观察者的角色,同时可以是组合对象、被组合对象、两者或两者都不是。

考虑一个典型的例子,其中按钮由控件组成。单击该按钮时,它会引发一个 Clicked 事件,该事件由包含的控件响应。在这种情况下,观察对象构成了被观察对象。

现在考虑一个由许多控件组成的屏幕。屏幕可能会引发 Closing 事件,该事件允许组合控件在整个屏幕关闭之前执行自己的清理工作。在这种情况下,被观察的对象构成了观察者。

现在考虑一个由按钮和标签组成的屏幕。单击按钮时,将调用标签的 Clear() 方法。在这种情况下,观察者和被观察者都不构成对方,但两者都是由屏幕对象构成的。

现在考虑一个屏幕,它引发一个它本身订阅的 Closing 事件(也许确保它自己是注册的最终事件处理程序)。当它引发 Closing 事件时,允许任何观察者首先执行他们可能需要的任何操作,然后它处理自己的事件。在这种情况下,观察者就是被观察者。

依赖注入涉及对象如何获取其依赖关系。注入给定对象的依赖项可能包含该对象想要订阅的事件,或者依赖项可能订阅它正在注入的对象。在一个对象被注入另一个对象之后,两个对象如何交互实际上与依赖注入没有任何关系。

EDIT

关于您的澄清部分,我相信我理解您困惑的根源。传统上,对象创建自己的依赖项。依赖注入通过将如何获取依赖关系的知识转移到对象之外来反转获取这些依赖关系的责任。然而,依赖注入不会反转依赖关系。您可能会将依赖注入与依赖倒置原则 http://www.ctrl-shift-b.com/2008/12/examining-dependency-inversion.html。依赖倒置原则确实颠倒了“高级”和“低级”对象之间的依赖关系,但依赖注入只关心如何将依赖提供给给定对象。因此,使用依赖注入不会改变对象之间通常交互的方式。如果在使用依赖项注入之前对象 B 订阅了对象 A 引发的事件(反之亦然),则引入依赖项注入不会改变这一点。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

依赖注入系统中的事件朝哪个方向发展? 的相关文章

  • Grails:在域类中动态注入服务

    我需要注入基于域属性的服务 到目前为止我想出了以下内容 ApplicationHolder application getServiceClass package property Service clazz 但以这种方式加载它不会注入它的
  • 以跨浏览器兼容的方式触发 onresize

    我想从后面的 C 代码触发 onresize 事件 我认为这可以完成 Page clientScript RegisterScriptBlock this getType id javascript code 我尝试过 element on
  • Mediatr 范围问题

    我正在使用 Mediatr 处理来自队列的消息 我可以得到一个简单的例子来工作 但是 当我尝试将对象注入到我的处理程序中时 我遇到了问题 public class MessageCommandHandler IRequestHandler
  • 抽象类、接口、mixins

    有人可以向我解释一下两者之间的区别吗抽象类 接口 and mixins 我之前在代码中使用过它们 但我不知道技术差异 抽象类 抽象类是不被设计为实例化的类 抽象类可以没有实现 部分实现或全部实现 抽象类旨在允许其子类共享公共 默认 实现 抽
  • 如何在两个类之间共享数据

    Question 有没有一种方法可以让两个类同时相互继承 背景 我目前正在开发一个 Socket Server 项目 在这个项目中 我有两个课程 一个Server类 以及一个GUI班级 他们的目的是不言自明的 但是 我显然需要让两个班级相互
  • .net 4.7 中的依赖注入?

    我对 DI 有哪些集成选项有点困惑 我发现它对于 net core 对于我的特定项目 来说非常简单 但我不需要构建跨平台应用程序 也看不到使用 core 的优势 但是 net 框架应用程序似乎仍然使用 Global asax 设置且没有 S
  • Java - 创建自定义事件和侦听器

    我正在尝试用 Java 创建自定义事件和侦听器 我已经看过这些文章和问题 在 Java 中创建自定义事件 https stackoverflow com questions 6270132 create a custom event in
  • 在调用超类的构造函数之前,有什么方法可以在Java中初始化子类的成员变量吗?

    我需要这个 因为超类中的构造函数正在调用子类中重写的方法 该方法返回一个值 该值被传递给子类的构造函数 但是超类构造函数必须在子类构造函数之前调用 所以我没有机会保存传入的值 从超类构造函数调用重写的方法根本行不通 不要这样做 超类构造函数
  • 框架时代的封装

    在我以前的 C 工作中 我们总是非常小心地封装成员变量 并且仅在绝对必要时才将它们作为属性公开 我们有非常具体的构造函数来确保您在使用对象之前完全构造了该对象 如今 使用 ORM 框架 依赖注入 序列化等 似乎您最好只依赖默认构造函数并在属
  • 创建活动时如何更改 Google 日历上的活动组织者?

    我正在使用 Google Calendar Api 创建事件 我试图将参数组织者与我想成为所有者的人的电子邮件一起传递 但它不起作用 并且组织者始终是同一创建者 None
  • 覆盖默认标识符生成策略对关联没有影响

    交响乐 2 7 2 学说 ORM 2 4 7 MySQL 5 6 12 PHP 5 5 0 我有一个具有自定义 ID 生成器策略的实体 它工作完美 在某些情况下 我必须使用 手工制作 的 ID 来覆盖此策略 当主实体在没有关联的情况下被刷新
  • asp.net mvc 4 - 可以在每个线程共享 DbContext 吗?

    From 每个 Web 请求一个 DbContext 为什么 https stackoverflow com questions 10585478 one dbcontext per web request why 我的理解是 DbCont
  • 非静态类中的静态方法和静态类中的静态方法有什么区别?

    我有两个班级A级和B级 static class ClassA static string SomeMethod return I am a Static Method class ClassB static string SomeMeth
  • 我应该使用课程吗? (Python)

    我正在尝试编写一个包含一些数学函数的小型 Python 模块 例如 它可能包含如下函数 def quad x a b c return a x 2 b x c 您可能会注意到它包含几个参数 即a b c 除了变量x 现在 如果我将其放入文件
  • 如何只获取父类对象的属性

    我有两节课 class Parent object def init self id name self id id self name name self parent vars id name make a copy def print
  • Dropwizard 和 Guice:注入环境

    我目前正在构建一个基于 Dropwizard Guice Jersey 的应用程序 其中数据库访问暂时由 JDBI 处理 我想要实现的是拥有典型的企业架构 其中资源访问服务类访问 DAO 类 而 DAO 类又访问数据库 如果能以正确的 DI
  • ASP.NET MVC:这个业务逻辑应该放在哪里?

    我正在开发我的第一个真正的 MVC 应用程序 并尝试遵循一般的 OOP 最佳实践 我正在将控制器中的一些简单业务逻辑重构到我的域模型中 我最近一直在阅读一些内容 很明显我应该将逻辑放在域模型实体类中的某个位置 以避免出现 贫血域模型 反模式
  • PHP 接口有属性吗?

    PHP 中的接口有属性 还是只有方法 您可以在 DocBlock 中为接口声明属性 然后 IDE 将提示接口的这些属性 PhpStorm 会这样做 但这不会强制在实现类中实际实现这些字段 例如 property string passwor
  • DI Control-Freak 反模式:难以理解

    我正在阅读 Mark Seemann 写的 NET 中的依赖注入 但我无论如何也无法理解这一点 虽然new当涉及到 VOLATILE 时 关键字是一种代码味道 依赖性 您无需担心将其用于稳定 依赖性 这new一般来说 关键字不会突然变得 非
  • tkinter - 使用按钮在帧之间来回切换

    我需要功能 最好是一个功能 当按下下一页和后退按钮时可以在页面之间来回切换 我想这可以通过将布尔变量分配给后退和下一页按钮来完成 不确定是否可以这样做 来确定您是否要前进或后退所有页面的有序列表 需要知道当前升高的框架的索引 索引可用于找出

随机推荐